我正在编写一个简单的解析器来将查询转换为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");
}
}
答案 0 :(得分:1)
我在代码中注意到的一个明显问题是生成的AND()
,OR()
和XOR()
方法返回TerminalNode
,但AND
,{ {1}}和OR
常量声明为XOR
。你真正想要使用的是表达式:
int
除此之外,您还需要包含所需输入和输出的更具体示例。