springboot 整合mybatis时,junit单元测试或打包时报无法找到Mapper中声明的方法

背景

最近搭建了一个简单的springboot+mybatis+thymelaf的项目,但是项目写了部分数据库代码后跑单元测试提示找不到Mapper中声明的,即如下错误:

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): xxx

之前测试的两个mapper方法都是能跑成功的,但现在也不行了,更蛋疼的是打包也报这个错误,但是直接启动项目,mapper里面的sql语句是能工作的,诡异的问题。

检查

确定以下配置没问题:

  • 在springboot 主类上加了@MapperScan 注解,并且设置了正确的包路径。
  • 在application.properties 中正确设置了xml文件的路径和model包的别名。
  • 将包含.xml mybatis的映射文件放在resource/mapper路径下
  • 打包后看到target/classes 下面有xx.xml文件

但是就是springboot junit单元测试时,报上面提到的错误

最后的解决办法

其实最早玩Mybatis的时候,它要求xxxMapper.xml 和xxxMapper.java 需要在同一个包下面,但是我这个直接放在mapper文件下,导致打包后没有和xxxMapper.java 在一个目录下,所以我想是不是这个原因导致的,试了一下果然可以。

即解决办法是: 将 resources下面的xxxMapper.xml的文件夹层次结构改为和xxxMapper.java的包的层次结构相同,即如果xxxMapper.java的包路径是com.sj.mapper, 那么resources下面的xxxMapper.xml的文件夹路径应该是com/sj/mapper/xxxMapper.xml。

猜测:
假如不按照上面的方面,直接改xxxMapper.xml 中的mapper 的namespace为看一下。

你好!对于Spring Boot整合MyBatisJUnit的问题,可以按照以下步骤进行操作: 1. 首先,确保你已经添加了相关的依赖。在`pom.xml`文件添加以下依赖: ```xml <dependencies> <!-- Spring Boot Starter --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- MyBatis Starter --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> </dependency> <!-- JUnit 5 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> ``` 2. 创建数据库配置。在`application.properties`文件添加数据库连接信息: ```properties spring.datasource.url=jdbc:mysql://localhost:3306/db_name spring.datasource.username=db_username spring.datasource.password=db_password spring.datasource.driver-class-name=com.mysql.jdbc.Driver # MyBatis配置 mybatis.mapper-locations=classpath:mapper/*.xml mybatis.type-aliases-package=com.example.domain ``` 3. 创建MyBatis映射配置文件。在`resources`目录下创建`mapper`目录,并编写对应的XML文件,例如`UserMapper.xml`: ```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.example.mapper.UserMapper"> <!-- SQL语句定义 --> </mapper> ``` 4. 创建实体类和Mapper接口。在`com.example.domain`包下创建实体类和对应的Mapper接口,例如`User.java`和`UserMapper.java`: ```java // User.java public class User { private Long id; private String name; // 省略getter和setter } // UserMapper.java @Mapper public interface UserMapper { User findById(Long id); // 其他方法定义 } ``` 5. 编写Service层和Controller层代码。按照你的业务需求编写对应的Service和Controller代码。 6. 编写JUnit测试代码。在`src/test/java`目录下创建测试类,例如`UserMapperTest.java`: ```java @SpringBootTest @RunWith(SpringRunner.class) public class UserMapperTest { @Autowired private UserMapper userMapper; @Test public void testFindById() { Long id = 1L; User user = userMapper.findById(id); Assert.assertNotNull(user); System.out.println(user.getName()); } } ``` 以上就是简单的Spring Boot整合MyBatisJUnit的步骤。根据你的具体需求,可以适当调整代码和配置。希望能对你有所帮助!如果还有其他问题,请继续提问。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值