做毕设的时候遇到的这个问题
首先我的项目在不适用 XML 的前提下的 CURD 都是成功的,但是只要一使用 XML ,那么就报上面的异常,项目结构如下
我的 Spring 版本是 3.4.2 、mybatis-plus 版本是 3.5.9
Mapper 接口中加入了 @Mapper 注解,启动类里也加入了 MapperScan 扫描
resource 中的 xml 我是在 application 中指定了扫描路径的
mybatis-plus:
  mapper-locations: classpath*:/mapper/**/*.xml
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.rolin.orange.orangecommon.mapper.UserMapper">
    <select id="getAll" resultType="com.rolin.orange.orangecommon.model.user.entity.User">
        select * from user
    </select>
</mapper>
Mapper 代码也没有问题,可以成功编译,可以成功启动
在编译后的结果里,可以找到对应的 xml 文件
感觉不管是哪里都没有问题,但是只要调用接口,就会报下面的异常
org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.rolin.orange.orangecommon.mapper.UserMapper.getAll
	at org.apache.ibatis.binding.MapperMethod$SqlCommand.<init>(MapperMethod.java:229) ~[mybatis-3.5.16.jar:3.5.16]
	at com.baomidou.mybatisplus.core.override.MybatisMapperMethod.<init>(MybatisMapperMethod.java:50) ~[mybatis-plus-core-3.5.9.jar:3.5.9]
	at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.lambda$cachedInvoker$0(MybatisMapperProxy.java:99) ~[mybatis-plus-core-3.5.9.jar:3.5.9]
	at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1708) ~[na:na]
	at org.apache.ibatis.util.MapUtil.computeIfAbsent(MapUtil.java:36) ~[mybatis-3.5.16.jar:3.5.16]
	at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.cachedInvoker(MybatisMapperProxy.java:97) ~[mybatis-plus-core-3.5.9.jar:3.5.9]
	at com.baomidou.mybatisplus.core.override.MybatisMapperProxy.invoke(MybatisMapperProxy.java:89) ~[mybatis-plus-core-3.5.9.jar:3.5.9]
	at jdk.proxy2/jdk.proxy2.$Proxy98.getAll(Unknown Source) ~[na:na]
	at com.rolin.orange.orangecommon.service.UserService.getAll(UserService.java:84) ~[classes/:na]
	at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:103) ~[na:na]
	at java.base/java.lang.reflect.Method.invoke(Method.java:580) ~[na:na]
我最后怀疑会是依赖的问题,但是查了下,springboot3.4.2 对应的 mybatisplus 版本就是 3.5.9 ,这个应该也没问题
根据上一个帖子下面的回复,是我 xml 的路径配置有问题,所以我改动了结构,将 xml 文件直接放在 mapper 下,具体来说是下面这样的
在编译后的文件里也能正确找到这两个 xml 文件
启动之后的情况是,对于 UserMapper 的接口,是可以正确调用的,但是对于 Attachment 的接口,却还是报上面的问题
AttachmentMapper 的代码如下
@Mapper
public interface AttachmentMapper extends BaseMapper<Attachment> {
    List<Attachment> findNeedCleared();
}
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.rolin.orange.orangecommon.mapper.AttachmentMapper">
    <select id="findNeedCleared" resultType="com.rolin.orange.orangecommon.model.attachment.entity.Attachment"
            databaseId="mysql">
        select *
        from attachment
        where confirmation_flag=0
          and to_days(now()) - to_days(update_date)>30
          and status=1
    </select>
    
</mapper>
我是哪里出了问题?这个问题又该如何解决呢?有没有懂得大佬来救下,小弟我是感激不尽啊
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.