首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用JSQLParser识别SQL中的函数调用

用JSQLParser识别SQL中的函数调用
EN

Stack Overflow用户
提问于 2012-02-24 05:37:32
回答 1查看 3.9K关注 0票数 2

如何使用JSQLParser区分函数调用和字段名称?

例如,查询SELECT COUNT(*) FROM db.tableCOUNT(*)解析为字段名,而不是函数调用。

我需要做什么才能改变SQL解析,将COUNT(*)显示为函数调用?

谢谢,

最大值

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-02-24 14:15:25

您没有样例代码,所以下面的代码是基于我的猜测,即您想要显示count(*)实际上只是一个函数调用。

代码语言:javascript
复制
import java.io.StringReader;

import net.sf.jsqlparser.JSQLParserException;
import net.sf.jsqlparser.expression.Function;
import net.sf.jsqlparser.parser.CCJSqlParserManager;
import net.sf.jsqlparser.statement.select.PlainSelect;
import net.sf.jsqlparser.statement.select.Select;
import net.sf.jsqlparser.statement.select.SelectExpressionItem;

public class MySQLParser
{
    CCJSqlParserManager parserManager = new CCJSqlParserManager();

    public MySQLParser() throws JSQLParserException
    {
        String statement = "SELECT COUNT(*) FROM db.table1";
        PlainSelect plainSelect = (PlainSelect) ((Select) parserManager.parse(new StringReader(statement))).getSelectBody();        
        System.out.format("%s is function call? %s",
                plainSelect.getSelectItems().get(0),
                ((Function)((SelectExpressionItem) plainSelect.getSelectItems().get(0)).getExpression()).isAllColumns());
    }
    public static void main(String[] args) throws JSQLParserException
    {

        new MySQLParser();

    }

}
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9421737

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档