0

我正在编写一个简单的解析器来将查询转换为 SQL。我已经完成了解析器并获得了解析树,但现在我需要使用 ANTLR 4 将这些语法转换为 SQL。

如果我的部分语法看起来像

boolOp : OR|XOR|AND;

如果存在任何匹配项,我将如何打印?

实际上,我正在尝试打印AND如果我的查询存在AND运算符或我的查询存在OR,那么我必须OR根据boolOp上面显示的语法规则打印运算符。

我的部分代码

public void exitBoolOp( Parser.BoolOpContext ctx)
{
    if (ctx.AND() == AND)
    {
        System.out.print(" AND "+"\t");
    }
    else if (ctx.OR() == OR)
    {
        System.out.print(" OR "+"\t");
    }
    else
    {
        System.out.print(" XOR "+"\t");
    }
}
4

1 回答 1

1

我在代码中注意到的一个明显问题是生成AND()OR(), 和XOR()方法返回 a TerminalNode,但是AND,ORXOR常量被声明为int. 您真正想要使用的是表达式:

if (ctx.AND() != null) {
    ...

除此之外,您还需要包含更多关于所需输入和输出的具体示例。

于 2013-08-24T15:18:20.043 回答