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文件。如下图所示:
再次强调,在intelliJ中resources下的路径分隔符用“.”(点号)是无效的,对应在文件夹中会生成一个名为“xx.xx.xx”的文件夹,并不是嵌套的文件夹!!!