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

posted @ 2019-04-12 14:10  DMY小天天  阅读(2529)  评论(0编辑  收藏  举报