遇到Invalid bound statement (not found)踩的坑

本文记录了在使用Spring Boot与Mybatis进行单元测试时,如何解决mapper接口找不到的问题,重点在于XML映射文件的正确编译路径配置。通过新建包结构并调整mapper-locations配置,解决了mapper文件未按预期编译的问题。

代码

@RunWith(SpringRunner.class)
@SpringBootTest
public class MybatisTest {
    @Autowired
    private DataSource dataSource;
    @Autowired
    private MemberPOMapper memberPOMapper;

    private Logger log=LoggerFactory.getLogger(MybatisTest.class);
    @Test
    public void testMapper(){
        BCryptPasswordEncoder passwordEncoder = new BCryptPasswordEncoder();
        String source="123123";
        String encode = passwordEncoder.encode(source);
        MemberPO memberPO = new MemberPO(null, "jack", encode,
                "杰克", "jack@qq.com", 1, 1, "杰克",
                "123123", 2);
        memberPOMapper.insert(memberPO);

    }
    }

遇到的问题

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.atguigu.crowd.mapper.MemberPOMapper.insert

看了一下我的application.yml是没有问题的

server:
  port: 2000
spring:
  application:
    name: atguigu-crowd-mysql
  datasource:
    name: mydb
    type: com.alibaba.druid.pool.DruidDataSource
    url: jdbc:mysql://127.0.0.1:3306/project_crowd?serverTimezone=UTC
    username: root
    password: 123456
    driver-class-name: com.mysql.cj.jdbc.Driver
eureka:
  client:
    service-url:
      defaultZone: http://localhost:1000/eureka
mybatis:
  mapper-locations: classpath*:/mybatis/mapper/*Mapper.xml
logging:
  level:
    com.atguigu.crowd.mapper: debug
    com.atguigu.crowd.test: debug

原因

排查后发现xml并没有像接口那样按照文件层级编译,而是被当做了一个文件夹名为mybatis.mapper的文件夹处理。

操作

重新建mybatis包和mapper包,记住要分开建包,然后删除之前的target,重新运行,然后就成功了。

结果

在这里插入图片描述

在数据库操作中,特别是在使用如 MyBatis 等持久层框架时,`invalid bound statement (not found)` 错误通常表明框架无法找到与指定 ID 匹配的 SQL 映射语句。以下是一些常见的原因及对应的解决方法: ### 1. 检查 SQL 映射文件的命名空间和语句 ID 确保调用的 SQL 语句 ID 与 XML 映射文件中定义的 ID 完全一致。同时,确认命名空间(namespace)也正确无误。例如,在 XML 文件中: ```xml <mapper namespace="com.example.mapper.UserMapper"> <select id="selectUserById" resultType="com.example.model.User"> SELECT * FROM users WHERE id = #{id} </select> </mapper> ``` 调用时应使用 `com.example.mapper.UserMapper.selectUserById` 作为语句 ID [^1]。 ### 2. 验证映射文件是否被正确加载 确保所有的 SQL 映射文件都被正确地加载到框架配置中。如果使用的是 MyBatis,可以在配置文件中添加如下内容来指定映射文件的位置: ```xml <configuration> <mappers> <mapper resource="com/example/mapper/UserMapper.xml"/> </mappers> </configuration> ``` 或者,如果希望自动扫描包含映射接口或注解的包,可以使用: ```xml <configuration> <mappers> <package name="com.example.mapper"/> </mappers> </configuration> ``` ### 3. 检查数据库操作的参数传递 当传递参数给 SQL 语句时,确保参数名称与映射文件中的 `#{}` 占位符相匹配。例如,如果映射文件中使用了 `#{userId}`,则传递的参数对象中必须包含名为 `userId` 的属性 。 ### 4. 确认数据库连接和事务管理配置正确 有时,错误也可能源于数据库连接或事务管理的配置不当。确保数据库连接池配置正确,并且事务边界处理得当。对于 MyBatis,通常会结合 Spring 框架进行事务管理,相关配置可能如下: ```xml <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> <tx:annotation-driven transaction-manager="transactionManager"/> ``` ### 5. 使用日志输出 SQL 语句 启用框架的日志功能可以帮助定位问题。通过查看日志,可以确认框架是否成功找到了并执行了预期的 SQL 语句。在 MyBatis 中,可以通过设置日志级别为 `DEBUG` 来开启此功能: ```xml <configuration> <settings> <setting name="log4j2" value="true"/> </settings> </configuration> ``` ### 6. 检查依赖版本兼容性 有时候,不同版本之间的库可能存在兼容性问题,导致某些功能无法正常工作。检查项目中所有相关的依赖版本,确保它们之间相互兼容。特别是,注意 MyBatis 及其与 Spring 集成插件的版本 。 以上措施应该能够帮助解决大多数 `invalid bound statement (not found)` 错误的情况。如果问题依旧存在,建议仔细检查错误日志,寻找更多线索,或者尝试简化问题场景,逐步排除可能的故障点。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值