oracle connect by prior 递归查询

oracle可以使用start with... connect by prior实现递归查询,即可查询树形结构的数据,使用方法如下:

e.g:

select * 
from table_name t
start with t.columnName_A = 'value'
connect by prior t.columnName_B = t.columnName_A

上述例子中,columnName_A为你要查询的关键字段,从"value"开始向上查询,其父结点是columnName_B字段


很有意思的是,在PL/SQL中,prior的位置不会影响它的查询结果,如下例子:

select * 
from table_name t
start with t.columnName_A = 'value'
connect by t.columnName_A = prior t.columnName_B

这两段SQL的执行结果是一样的


但当第二段SQL放在持久层(我用的mybatis)中执行的时候就会报这样的错误:

[sql parser]
net.sf.jsqlparser.JSQLParserException
	at net.sf.jsqlparser.parser.CCJSqlParserUtil.parse(CCJSqlParserUtil.java:51)
Caused by: net.sf.jsqlparser.parser.ParseException: Encountered " <S_IDENTIFIER> "t "" at line 1, column 84.
Was expecting one of:
    "NOT" ...
    "NOCYCLE" ...
    "(" ...
    "NOCYCLE" ...
    "(" ...
    "NOT" ...
    "NOT" ...
    "NOT" ...
    "NOT" ...
    "(" ...
    "(" ...
    "NOT" ...
    "NOT" ...
    "NOT" ...
    
	at net.sf.jsqlparser.parser.CCJSqlParser.generateParseException(CCJSqlParser.java:10444)
	at net.sf.jsqlparser.parser.CCJSqlParser.jj_consume_token(CCJSqlParser.java:10303)
	at net.sf.jsqlparser.parser.CCJSqlParser.AndExpression(CCJSqlParser.java:2764)
	at net.sf.jsqlparser.parser.CCJSqlParser.OracleHierarchicalQueryClause(CCJSqlParser.java:2381)
	at net.sf.jsqlparser.parser.CCJSqlParser.PlainSelect(CCJSqlParser.java:1154)
	at net.sf.jsqlparser.parser.CCJSqlParser.SelectBody(CCJSqlParser.java:1045)
	at net.sf.jsqlparser.parser.CCJSqlParser.Select(CCJSqlParser.java:1033)
	at net.sf.jsqlparser.parser.CCJSqlParser.SingleStatement(CCJSqlParser.java:75)
	at net.sf.jsqlparser.parser.CCJSqlParser.Statement(CCJSqlParser.java:55)
	at net.sf.jsqlparser.parser.CCJSqlParserUtil.parse(CCJSqlParserUtil.java:49)
	... 36 more

使用第一段代码在持久层执行就没有问题

目前此问题我猜测原因应该是connect by prior这三个词在mybatis中是联合使用的,不能拆分开来,不过也可能是我用的底层代码有进行重封装过,所以必须这样用

先标记问题,等以后有时间了再看看是什么原因(微笑)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值