java创建xml设置路径_详解mybatis-plus的 mapper.xml 路径配置的坑

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.(MybatisMapperMethod.java:242)

at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.(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 目录

1927159738efbc37cff8fbf036cd4122.png

代码如下:

单元测试

@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

SELECT

user_id,

user_account,

user_password,

user_phone

FROM t_system_user

where user_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

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">

4.0.0

org.springframework.boot

spring-boot-starter-parent

2.2.2.RELEASE

com.example

demo

0.0.1-SNAPSHOT

demo

Demo project for Spring Boot

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

# DataSource Config

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")

public class MybatisConfig {

/**mybatis-plus 分页插件*/

@Bean

public PaginationInterceptor paginationInterceptor() {

return new PaginationInterceptor();

}

}

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

276bb70e6babc0dc5cbb1118e00b5e57.png

单元测试

@SpringBootTest

class DemoApplicationTests {

@Autowired

SystemUserService systemUserService;

@Test

public void findUser(){

SystemUser systemUser= systemUserService.findUserByName("admin");

System.out.println(systemUser.toString());

}

}

b4f89233b0aed418af755caab11ebe48.png

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

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值