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”的文件夹,并不是嵌套的文件夹!!!

原创文章 8 获赞 16 访问量 8206

猜你喜欢

转载自blog.csdn.net/xingzhe123456789000/article/details/104996148