源码分析MyCat之SQL解析篇-----sql解析引擎druid之抽象语法树(mycat1

图片如果不清晰,建议下载原图浏览。

基于如下SQL举例说明如下对象:

select a.id,a.name,(select count(1) from acc_b b where b.user_id=a.id) as num from acc_user a

  • SQLExpr 表达式根接口对象

  • SQLPropertyExpr 查询字段列表,比如上面查询列表中的 a.id ,a.name 就是用一个SQLPropertyExpr表示

  • SQLIdentifierExpr 一般表示表名或别名,还是上面的a.id,整体是一个SQLPropertyExpr,但SQLPropertyExpr由owner与name组成,其中name为id,而表的别名由owner来表示,也就是一个SQLIdentiferExpr,如图所示:

  • SQLAllColumnExpr 查询字段(*)的表示符

  • SQLLiteralExpr 字面量表示,其子类如下:

  • SQLIntegerExpr 整数型字面量表达式,比如 where a.id = 1 ,其中1就是用SQLIntegerExpr来表示。下面的类似

  • SQLBooleanExpr

  • SQLNumericLiteralExpr

  • SQLCharExpr

  • SQLDateExpr

  • SQLTextLiteralExpr

  • SQLTimestampExpr

  • SQLAllExpr、SQLSomeExpr、SQLAnyExpr 运算符 all,some、any。

  • 17
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值