详解mybatis-plus配置找不到Mapper接口路径的坑

时间:2021-05-19

mybatis-plus今天遇到一个问题,就是mybatis 没有读取到mapper.xml 文件。

特此记录一下,问题如下:

at com.baomidou.mybatisplus.core.override.MybatisMapperMethod$SqlCommand.<init>(MybatisMapperMethod.java:242)
at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:54)
at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedMapperMethod$0(MybatisMapperProxy.java:65)
at java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1660)
at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedMapperMethod(MybatisMapperProxy.java:65)
at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:60)
at com.sun.proxy.$Proxy72.findUserByName(Unknown Source)
at com.husy.service.impl.SystemUserServiceImpl.findUserByName(SystemUserServiceImpl.java:23)org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.husy.mapper.SystemUserMapper.findUserByName

错误代码如下:

mapper.xml 目录


代码如下:

单元测试

@Testpublic void findUser(){ SystemUser systemUser= systemUserService.findUserByName("admin"); System.out.println(systemUser.toString());}

mybatis-puls 配置

@EnableTransactionManagement@Configuration@MapperScan("com.husy.mapper")public class MybatisConfig { /** * mybatis-plus 分页插件 */ @Bean public PaginationInterceptor paginationInterceptor() { return new PaginationInterceptor(); }}

service实现

@Servicepublic class SystemUserServiceImpl implements SystemUserService { @Autowired private SystemUserMapper userMapper; @Override public SystemUser findUserByName(String name) { return userMapper.findUserByName(name); }}

mapper 接口

@Componentpublic interface SystemUserMapper { SystemUser findUserByName(@Param("userAccount") String name);}

mapper.xml

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.husy.mapper.SystemUserMapper"> <resultMap id="systemUserMap" type="com.husy.domain.SystemUser" > <id column="user_id" property="userId" /> <result column="user_account" property="userAccount" /> <result column="user_password" property="userPassword" /> <result column="user_phone" property="userPhone" /> </resultMap> <select id="findUserByName" resultMap="systemUserMap"> SELECT user_id, user_account, user_password, user_phone FROM t_system_user where user_account = #{userAccount} </select></mapper>

通过上面的代码可以看出。mapper接口中的方法和映射文件中的方法名称是一样的。不存在名称错误导致的情况,返回值,参数类型等你都正确。如果找不到方法,那一定是映射文件配置问题,只有没有读取到,才会出现找不到的情况。
我的配置如下:

问题出错的关键位置

我这里引用的是 mybatis-plus-boot-starte 依赖

<dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.1.0</version> </dependency>

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 包

<dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus</artifactId> <version>3.1.0</version></dependency>mybatis.mapper-locations=classpath:mapper/*.xml

引用 mybatis-plus-boot-starter 包

<dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.1.0</version> </dependency>mybatis-plus.mapper-locations=classpath:mapper/*.xml

只要选用其中一种方式,就没有问题了。

今天看到评论区有小伙伴说没有作用,这里给了一份Demo ,有问题的小伙伴可以比对一下。

POM

<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://.example.demo.mapper")public class MybatisConfig { /**mybatis-plus 分页插件*/ @Bean public PaginationInterceptor paginationInterceptor() { return new PaginationInterceptor(); }}

其他文件基本没变化。附上目录

单元测试

@SpringBootTestclass DemoApplicationTests { @Autowired SystemUserService systemUserService; @Test public void findUser(){ SystemUser systemUser= systemUserService.findUserByName("admin"); System.out.println(systemUser.toString()); }}

到此这篇关于详解mybatis-plus配置找不到Mapper接口路径的坑的文章就介绍到这了,更多相关mybatis-plus找不到Mapper接口路径内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章