intelliJ IDEA下MyBatis开发常犯错误

MyBatis xml文件无法绑定DAO层接口

报错内容:

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found XXXX.XXXX.XXMapper)

报错内容分析:
mybatis无法将xml文件和对应的接口文件进行绑定。

方法一:maven文件过滤设置

MyBatis中,DAO层的接口文件和对应的xml文件名字必须一致,无特别设置需要在同一路径下,如果使用maven开发,则需要将源码目录下的xml文件进行资源文件的过滤设置。

<build>
    <finalName>test</finalName>
    <!--
    这样也可以把所有的xml文件,打包到相应位置。
    <resources>
        <resource>
            <directory>src/main/resources</directory>
            <includes>
                <include>**/*.properties</include>
                <include>**/*.xml</include>
                <include>**/*.tld</include>
            </includes>
            <filtering>false</filtering><--这里是false,用true会报 数据库连接 错误-->
        </resource>
        <resource>
            <directory>src/main/java</directory>
            <includes>
                <include>**/*.properties</include>
                <include>**/*.xml</include>
                <include>**/*.tld</include>
            </includes>
            <filtering>false</filtering>
        </resource>
    </resources>
</build>

方法二:resources下将xml文件路径和接口路径统一

通过方法一,可以保证xml文件和mapper接口的对应。
但是这样容易造成视觉上的堆积和别扭,解决该问题可以通过在resources(资源根目录)下设置和接口文件相同的路径,这样在build之后,就可以将xml文件和对应的class文件放在同一路径下。通过该方法,也无需在maven的pom文件中设置filtering。

特别的,需要注意intelliJ下资源路径的分隔符

在intelliJ中,资源路径下的路径分隔符是“/”,代码路径下的路径分隔符是“.”,因为这个问题,导致我好长时间没有发现问题所在。

问题排查方法

在工程中打开生成代码的target文件下的classes文件夹下,可以找到生成的.class文件,如果可以找到对应的xml文件,就表示MyBatis可以绑定接口和xml文件。如下图所示:
target目录下dao层中可以看到xm文件和class文件可以对应起来
再次强调,在intelliJ中resources下的路径分隔符用“.”(点号)是无效的,对应在文件夹中会生成一个名为“xx.xx.xx”的文件夹,并不是嵌套的文件夹!!!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值