项目启动时 xml报错:Could not find SQL statement to include with refid 'mbgl.panDuanZbsfkxg'


本文地址:https://blog.csdn.net/QQ826688096/article/details/89235500

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


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM