评论

收藏

[PHP] 项目启动时 xml报错:Could not find SQL statement to include with refi...

开发技术 开发技术 发布于:2021-12-28 16:59 | 阅读数:513 | 评论:0

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>方法放到该文件的最前面就可以了。


关注下面的标签,发现更多相似文章