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中是联合使用的,不能拆分开来,不过也可能是我用的底层代码有进行重封装过,所以必须这样用
先标记问题,等以后有时间了再看看是什么原因(微笑)