Mybatis - 在idea中错误:Invalid bound statement (not found)

在学习Mybatis时遇到一个问题,即在IDEA中测试mapper自动代理功能失败,而同样的代码在Eclipse中正常工作。原因是IDEA默认不会把源代码目录下的xml资源文件编译进classes文件夹,而Eclipse则会。解决方案包括将xml文件移至resource目录或在maven的resources配置中包含这些文件。通过配置maven的资源过滤,可以确保XML文件被正确处理和打包。

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

学习mybatis的过程中,测试mapper自动代理的时候一直出错,在eclipse中可以正常运行,而同样的代码在idea中却无法成功。虽然可以继续调试,但心里总是纠结原因。百度了好久,终于找到一个合适的原因。参

原因:(参考:http://www.linuxidc.com/Linux/2015-06/118877.htm)

IDEA的maven项目中,默认源代码目录下的xml等资源文件并不会在编译的时候一块打包进classes文件夹,而是直接舍弃掉。

如果使用的是Eclipse,Eclipse的src目录下的xml等资源文件在编译的时候会自动打包进输出到classes文件夹。Hibernate和Spring有时会将配置文件放置在src目录下,编译后要一块打包进classes文件夹,所以存在着需要将xml等资源文件放置在源代码目录下的需求。

解决:

方法1:将xml或properties等配置文件放到resource下,并修改获取配置文件的代码,比如注册mapper.xml的位置等;

方法2:在maven中添加过滤:

<!--配置Maven 对resource文件 过滤 -->

<resources>

<resource>

<directory>src/main/resources</directory>

<includes>

<include>**/*.properties</include>

<include>**/*.xml</include>

</includes>

<filtering>true</filtering>

</resource>

<resource>

<directory>src/main/java</directory>

<includes>

<include>**/*.properties</include>

<include>**/*.xml</include>

</includes>

<filtering>true</filtering>

</resource>

</resources>

我采用mybatis的自动代理设置,将mapper文件和xml文件同名同包下,并在sqlMap.xml(mybatis-config.xml)中配置mapper自动注册扫描包:

<mappers>

<mapper resource="sqlmap/User.xml"/>

<!--通过resource方法一次加载一个映射文件 -->

<!--<mapper resource="sqlmap/UserMapper.xml"/>-->

<!-- 通过mapper接口加载单个 映射文件

遵循一些规范:需要将mapper接口类名和mapper.xml映射文件名称保持一致,且在一个目录 中

上边规范的前提是:使用的是mapper代理方法

-->

<!--<mapper class="cn.itcast.mybatis.mapper.UserMapper"/>-->

<!-- 批量加载mapper

指定mapper接口的包名,mybatis自动扫描包下边所有mapper接口进行加载

遵循一些规范:需要将mapper接口类名和mapper.xml映射文件名称保持一致,且在一个目录 中

上边规范的前提是:使用的是mapper代理方法

-->

<package name="cn.itcast.mybatis.mapper"/>

</mappers>

不管是在多modul 下进行配置还是单个工程下,均是这样配置;

idea 的 多modul 下 ,只需要在 root 项目的 maven 下进行配置即可! 当然配置在 pom.xml 中的  标签下!

example :

<build>

<plugins>

<plugin>

<groupId>org.mortbay.jetty</groupId>

<artifactId>maven-jetty-plugin</artifactId>

<version>6.1.7</version>

<configuration>

<connectors>

<connector implementation="org.mortbay.jetty.nio.SelectChannelConnector">

<port>8888</port>

<maxIdleTime>30000</maxIdleTime>

</connector>

</connectors>

<webAppSourceDirectory>${project.build.directory}/${pom.artifactId}-${pom.version}</webAppSourceDirectory>

<contextPath>/</contextPath>

</configuration>

</plugin>

</plugins>

<!--这里进行配置,后会自动的加载mapper.xml文件 :配置Maven 对resource文件 过滤 -->

<resources>

<resource>

<directory>src/main/resources</directory>

<includes>

<include>**/*.properties</include>

<include>**/*.xml</include>

</includes>

<filtering>true</filtering>

</resource>

<resource>

<directory>src/main/java</directory>

<includes>

<include>**/*.properties</include>

<include>**/*.xml</include>

</includes>

<filtering>true</filtering>

</resource>

</resources>

</build>

Mybatis - 在idea中错误:Invalid bound statement (not found)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值