mybatis-plus的 mapper.xml 路径配置的坑

本文记录了在使用Mybatis-Plus时遇到的mapper.xml文件未被读取的问题,详细分析了错误原因并提供了正确的配置方法,包括mybatis-plus.mapper-locations和mybatis.mapper-locations的区别。

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

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

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.husy.mapper.SystemUserMapper.findUserByName

    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)


错误代码如下:

mapper.xml 目录(在resources目录中的mapper)

代码如下:

单元测试

@Test
public 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实现

@Service
public class SystemUserServiceImpl implements SystemUserService {
    @Autowired
    private SystemUserMapper userMapper;

    @Override
    public SystemUser findUserByName(String name) {
        return userMapper.findUserByName(name);
    }
}


mapper 接口

@Component
public 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 包

 

mybatis-plus.mapper-locations=classpath:mapper/*.xml

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值