Druid是否有国内站点?公司上不去github,谢谢!
原提问者GitHub用户zxj19880903
是的,Druid有国内的官方站点。Druid的官方网站是https://druid.apache.org/,同时也有国内的官方站点https://druid.apache.org.cn/。这个站点提供了Druid的中文文档、社区论坛、下载链接、开源代码等资源,方便国内用户使用和学习Druid。
上开源中国的maven仓库下载。 http://maven.oschina.net/index.html#nexus-search;gav~com.alibaba~druid~~~
原回答者GitHub用户bluesbruce
获得 SELECT 语句的查询项(即选出的字段)是 SQL 解析器中一个比较复杂的点,尤其是在涉及到子查询、别名、函数以及其他 SQL 语法成分的时候。下面介绍几种常见的方法,你可以根据自己的需求选择适合的方式:
使用 SQL 解析工具库进行语法分析,获取选出的字段。 通用的 SQL 解析器无法直接解析 SQL 语句中的 alias 和嵌套子查询等情况。 需要使用解析工具库对 SQL 语句进行更高阶段的解析。常见的 SQL 解析工具库有 Apache Calcite、ANTLR、JSqlParser、druid 等。
以 JSqlParser 为例,可以将 SELECT 查询语句解析为 PlainSelect 对象,然后从中获取查询项。 示例代码如下:
String sql = "SELECT u., u.name, u.age, (SELECT COUNT() FROM users) AS total FROM users u"; Select select = JSqlParserUtil.parse(sql);
if (select instanceof Select) { SelectBody selectBody = ((Select) select).getSelectBody(); if (selectBody instanceof PlainSelect) { PlainSelect plainSelect = (PlainSelect) selectBody; List selectItems = plainSelect.getSelectItems();
// 遍历查询项,获取选出的字段
for (SelectItem item : selectItems) {
if (item instanceof SelectExpressionItem) {
SelectExpressionItem expItem = (SelectExpressionItem) item;
Expression exp = expItem.getExpression();
System.out.println(exp);
}
}
}
}
需要注意的是,这种方式实现起来比较复杂,而且会导致性能损失。
利用正则表达式获取查询项。 一些工具类库,比如 MyBatis、Spring JDBC 等都会解析 SQL 语句,在这种情况下,通过正则表达式来提取查询项是一种常用的方式。示例代码如下:
String sql = "SELECT u., u.name, u.age, (SELECT COUNT() FROM users) AS total FROM users u"; String selectExpr = sql.substring(sql.indexOf("SELECT") + "SELECT".length(), sql.indexOf("FROM")); Matcher matcher = Pattern.compile("\b([a-zA-Z0-9_]+\.)?[a-zA-Z0-9_]+").matcher(selectExpr); while (matcher.find()) { System.out.println(matcher.group()); }
这种方式无法处理一些复杂的 SQL 语句,例如嵌套的子查询、自定义函数等。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。