项目启动时 xml报错:Could not find SQL statement to include with refi...
Cause: java.lang.RuntimeException: Could not find SQL statement to include with refid 'mbgl.panDuanZbsfkxg'在xml(ibatis)里面使用了<include id="XXX">,然后,在对应的地方调用,
然后就报这个错误了。
错误分析:
主要是个人的代码习惯因素。因为本人总是习惯把复杂的代码都提取出来,都放到当前方法的下面新建立一个方法,一个是为了方便阅读,另一个就是方便维护。要不然找起来很麻烦的。
我将复杂的sql提取出来放在了当前方法的下面了,原因就出在这里。因为<include>语法规定了,必须要写在所有调用<include>的id值的方法之前才可以。这是ibatis在项目启动的时候加载时按照从上到下的顺序进行解析时,先找到了调用的方法,但是哪个方法里面引用了<include>方法,而xml的解析不会再去找<include>了。所以系统认为没有<include>,所以报错。
也就是说,必须先加载<include>后,才可以使用<include>。
解决:
将<include>方法放到该文件的最前面就可以了。
https://blog.51cto.com/u_6740008/4852659
页:
[1]