详解mybatis-plus的 mapper.xml 路径配置的坑
mybatis-plus今天遇到一个问题,就是mybatis没有读取到mapper.xml文件。
特此记录一下,问题如下:
org.apache.ibatis.binding.BindingException:Invalidboundstatement(notfound):com.husy.mapper.SystemUserMapper.findUserByName atcom.baomidou.mybatisplus.core.override.MybatisMapperMethod$SqlCommand.(MybatisMapperMethod.java:242) atcom.baomidou.mybatisplus.core.override.MybatisMapperMethod. (MybatisMapperMethod.java:54) atcom.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedMapperMethod$0(MybatisMapperProxy.java:65) atjava.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1660) atcom.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedMapperMethod(MybatisMapperProxy.java:65) atcom.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:60) atcom.sun.proxy.$Proxy72.findUserByName(UnknownSource) atcom.husy.service.impl.SystemUserServiceImpl.findUserByName(SystemUserServiceImpl.java:23)
错误代码如下:
mapper.xml目录
代码如下:
单元测试
@Test publicvoidfindUser(){ SystemUsersystemUser=systemUserService.findUserByName("admin"); System.out.println(systemUser.toString()); }
mybatis-puls配置
@EnableTransactionManagement @Configuration @MapperScan("com.husy.mapper") publicclassMybatisConfig{ /** *mybatis-plus分页插件 */ @Bean publicPaginationInterceptorpaginationInterceptor(){ returnnewPaginationInterceptor(); } }
service实现
@Service publicclassSystemUserServiceImplimplementsSystemUserService{ @Autowired privateSystemUserMapperuserMapper; @Override publicSystemUserfindUserByName(Stringname){ returnuserMapper.findUserByName(name); } }
mapper接口
@Component publicinterfaceSystemUserMapper{ SystemUserfindUserByName(@Param("userAccount")Stringname); }
mapper.xml
SELECT user_id, user_account, user_password, user_phone FROMt_system_user whereuser_account=#{userAccount}
通过上面的代码可以看出。mapper接口中的方法和映射文件中的方法名称是一样的。不存在名称错误导致的情况,返回值,参数类型等你都正确。如果找不到方法,那一定是映射文件配置问题,只有没有读取到,才会出现找不到的情况。
我的配置如下:
问题出错的关键位置
我这里引用的是mybatis-plus-boot-starte依赖
com.baomidou mybatis-plus-boot-starter 3.1.0
mapper.xml的文件引用路径配置如下:
mybatis.mapper-locations=classpath:mapper/*.xml
这就导致,mybatis读取不到mapper映射文件。
经过查阅:
- 如果引用mybatis-plus-boot-starter依赖,需要配置mybatis-plus.mapper-locations
- 如果引用mybatis-plus依赖,需要配置mybatis.mapper-locations
如下:
引用mybatis-plus包
com.baomidou mybatis-plus 3.1.0
mybatis.mapper-locations=classpath:mapper/*.xml
引用mybatis-plus-boot-starter包
com.baomidou mybatis-plus-boot-starter 3.1.0
mybatis-plus.mapper-locations=classpath:mapper/*.xml
只要选用其中一种方式,就没有问题了。
今天看到评论区有小伙伴说没有作用,这里给了一份Demo,有问题的小伙伴可以比对一下。
POM
4.0.0 org.springframework.boot spring-boot-starter-parent 2.2.2.RELEASE com.example demo 0.0.1-SNAPSHOT demo DemoprojectforSpringBoot 1.8 org.mybatis.spring.boot mybatis-spring-boot-starter 2.1.1 mysql mysql-connector-java runtime com.baomidou mybatis-plus-boot-starter 3.3.0 org.springframework.boot spring-boot-starter-test test org.junit.vintage junit-vintage-engine org.springframework.boot spring-boot-maven-plugin
application.properties
#DataSourceConfig spring.datasource.url=jdbc:mysql://localhost:3306/db_husy?allowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=GMT%2B8&zeroDateTimeBehavior=CONVERT_TO_NULL spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver mybatis-plus.mapper-locations=classpath:/mapper/*.xml
MybatisConfig
@EnableTransactionManagement @Configuration @MapperScan("com.example.demo.mapper") publicclassMybatisConfig{ /**mybatis-plus分页插件*/ @Bean publicPaginationInterceptorpaginationInterceptor(){ returnnewPaginationInterceptor(); } }
其他文件基本没变化。附上目录
单元测试
@SpringBootTest classDemoApplicationTests{ @Autowired SystemUserServicesystemUserService; @Test publicvoidfindUser(){ SystemUsersystemUser=systemUserService.findUserByName("admin"); System.out.println(systemUser.toString()); } }
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。