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

本文详细解析了一个关于ibatis(MyBatis前身)中<include>语句使用不当导致的运行时异常问题。错误核心在于<include>语句的位置不当,未遵循其必须在所有调用它的SQL语句之前定义的规则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文地址:https://blog.youkuaiyun.com/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>方法放到该文件的最前面就可以了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值