Mybatis 中Mapper使用package方式配置报错的解决方案
Mybatis 中Mapper使用package方式配置报错
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)

UserDaoTest中调用了UserDao的insert方法。
1.项目结构如下
package com.mybatis.dao; import org.apache.ibatis.annotations.Mapper;import org.apache.ibatis.annotations.Param; import java.util.List;import com.mybatis.pojo.User; @Mapperpublic interface UserDao { void insert( User user); int insertSelective(@Param('user') User user); int insertList(@Param('users') List<User> users); int update(@Param('user') User user); User findbyId(@Param('id')Integer id); }3.UserDao.xml


已经按照正常的package的配置方式,将接口与xml文件放在同一个目录下,其他配置也没问题,就是报找不到UserDao中的方法。
结果去target中看了一眼发现,xml文件没加载。。。。。
解决方案原来是IDEA maven项目默认不会把src下除java文件外的文件打包到classes文件夹下,需要在maven中增加配置如下
<build><resources> <resource><directory>src/main/java</directory><includes> <include>**/*.xml</include></includes><!--默认是true--><!--<filtering>true</filtering>--> </resource></resources> </build>
这样xml文件就可以加载了,动态代理为UserDao接口生成实现类,而实现类的具体实现细节就是在xml中,通过package扫描的方式找到xml,就可以正确的生成UserDao的代理类了。
而xml无法加载,就会造成动态代理生成的代理类是无效的(这个代理类对象是可以生成的),当调用方法就会出现开头的错误。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持好吧啦网。
相关文章:
1. Mysql入门系列:在MYSQL结果集上执行计算2. Delphi中的Access技巧集3. Windwos下MySQL 64位压缩包的安装方法学习记录4. Mysql入门系列:需要避免的MYSQL客户机程序设计错误5. Mysql故障排除:Starting MySQL. ERROR! Manager of pid-file quit without updating file6. 快速删除ORACLE重复记录7. 一文读懂navicat for mysql基础知识8. 学好Oracle的六条总结9. 搭建小型access数据库实录10. sql查询一个数组中是否包含某个内容find_in_set问题

网公网安备