Springboot 项目测试请求时总是报 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found),求大佬帮忙解决 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
tiRolin
V2EX    Java

Springboot 项目测试请求时总是报 org.apache.ibatis.binding.BindingException: Invalid bound statement (not found),求大佬帮忙解决

  •  1
     
  •   tiRolin 2024-10-04 06:36:24 +08:00 2439 次点击
    这是一个创建于 372 天前的主题,其中的信息能已经有所发展或是发生改变。

    我做了一个简单的 CURD 项目,但是这个项目测试接口时却总是报

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

    这个问题困扰了我快一天了,我一直没能解决它 下面是我的部分 Controller 和 Service 相关的代码 Controller 的部分

    @RestController @RequestMapping("/private/user/baseTestUser") public class BaseTestUserController { @Autowired private BaseTestUserService baseTestUserService; /** * 新增用 * @param baseTestUserInsertBo 用插入求象 * @return 新增用 id */ @ApiOperation("增加用方法") @PostMapping("/add") @AvoidRepeatableCommit public ResponseDTO<Long> insert( @ApiParam(name = "BaseTestUserInsertBo",value = "用插入象") @RequestBody @Valid BaseTestUserInsertBo baseTestUserInsertBo) { return ResponseDTO.ok(baseTestUserService.insert(baseTestUserInsertBo)); } } 

    Service 的部分

    @Service public class BaseTestUserService extends BaseService<BaseTestUserMapper, BaseTestUser> { @Autowired private BaseTestUserMapper baseTestUserMapper; @Transactional public Long insert(BaseTestUserInsertBo baseTestUserInsertBo) { BaseTestUser baseTestUser = baseTestUserInsertBo.toEntity(); baseTestUser.setRoleID(1); exist(baseTestUser); insert(baseTestUser); return baseTestUser.getId(); } /** * 用名唯一性查 * @param baseTestUser 用象 */ private void exist(BaseTestUser baseTestUser) { QueryWrapper<BaseTestUser> queryWrapper = new QueryWrapper<>(); // queryWrapper.lambda().ne(baseTestUser.getId() != null, BaseTestUser::getId, baseTestUser.getId()); queryWrapper.lambda().eq(BaseTestUser::getUsername, baseTestUser.getUsername()); long count = this.count(queryWrapper); BaseTestUserErrorEnum.BASE_USER_EXIST_SAME_NAME_ERROR.isTrue(count>0); } } 

    我觉得我的代码部分是没什么问题的,但是每次代码运行到 this.count(queryWrapper);这一行的时候就会报我上面所说的异常,但是我项目编译可以通过,我甚至可以按住 ctrl 进入到 count 的字节码文件里,按说是没问题的,但是却会报问题,我尝试了很多方法都没能解决这个问题,我实在是没法了,所以我来问问各位 下面是一些有关于我项目的更多内容,方便各位解决问题

    首先我使用的 jdk 版本是 21 ,maven 版本是 3.5.3 我在 pom 文件中引入了 mybatis 相关依赖,具体内容如下

     <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>3.0.3</version> </dependency> 

    事实上,我即使不引入这个依赖,在我的依赖中也已经存在 mybatis 和 mybatisplus 的相关内容了,但是我没引入这个依赖之前启动项目会报

    Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required 

    为了解决这个问题,我引入了这个依赖

    下面是我的项目本体结构

    我项目配置类的代码如下所示:

    spring.application.name=jarlearning21 spring.datasource.url=jdbc:mysql://localhost:3306/database?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezOne=Asia/Shanghai spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver server.port=8081 mybatis.mapper-locatiOns= classpath*:org/example/jarlearning21/user/mapper/**/*.xml mybatis-plus.type-aliases-package=org.example.jarlearning21.user.model.po 

    启动类的代码如下

    @SpringBootApplication(exclude = {SecurityAutoConfiguration.class}) @MapperScan("org.example.jarlearning21.user.mapper") public class Jarlearning21Application { public static void main(String[] args) { SpringApplication.run(Jarlearning21Application.class, args); } } 

    Mapper 的代码

    public interface BaseTestUserMapper extends BaseMapper<BaseTestUser> {} 

    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="org.example.jarlearning21.user.mapper.BaseTestUserMapper"> </mapper> 

    以上就是所有内容,如果需要更多信息请随时跟我说,我会第一时间补充,先谢谢各位了

    26 条回复    2024-10-18 17:04:56 +08:00
    tiRolin
        1
    tiRolin  
    OP
       2024-10-04 06:37:59 +08:00
    这几天在这里问的问题可能有些多,多有打扰,但是我都是确实解决不了才来问各位的,我在这里问的问题基本我自己是尝试过许多办法去解决都还行不通我才来问的,不是说单纯把各位当做什么好用的工具了有事就来问,我是实在没办法了才来向各位请教的
    如有打扰还望多多包涵,实在不好意思
    linmt
        2
    linmt  
       2024-10-04 07:25:56 +08:00
    mybatis.mapper-locatiOns= classpath*:org/example/jarlearning21/user/mapper/**/*.xml

    这个配置的意思是匹配文件 resources/org/example/jarlearning21/user/mapper/**/*.xml
    montaro2017
        3
    montaro2017  
       2024-10-04 09:32:55 +08:00
    你的 xml 文件没放在 resource 面,编译后 xml 文件没有写出,如果你非要放在`main/java`下面,需要在 pom.xml 中配置,或者直接放在 resource 文件夹下面
    montaro2017
        4
    montaro2017  
       2024-10-04 09:34:14 +08:00
    @montaro2017 #3 你可以看你编译后的 target 目录里面有没有这个 xml 文件,看一眼就知道了,如果你把 xml 放在 resources 目录下,就没这个问题
    Duolingo
        5
    Duolingo  
       2024-10-04 10:30:13 +08:00 via Android
    xml 路径问题
    chuck1in
        6
    chuck1in  
       2024-10-04 10:52:08 +08:00
    这个论坛新手还挺少的,帮 lz 顶一下。
    chuck1in
        7
    chuck1in  
       2024-10-04 10:53:53 +08:00
    对了,既然 op 都用 jdk21 了为什么不试试这个项目呢

    https://www.bilibili.com/video/BV1x6xXe2Erp/
    tiRolin
        8
    tiRolin  
    OP
       2024-10-04 20:25:40 +08:00 via Android
    @codingadog 并非是路径问题,我已经在 pom 文件中加了对应的配置了, 我很确定编译后的项目是由 XML 这个文件的,事实上,当我在 XML 里自定义方法的时候,也可以正常调用,问题在于,mybatisplus 应该提供给我事先设置好的方法,但当我调用他们的时候,总是会报错我的问题,主要在这里
    tiRolin
        9
    tiRolin  
    OP
       2024-10-04 20:28:19 +08:00
    @montaro2017 并非是路径问题,我已经在 pom 文件中加了对应的配置了, 我很确定编译后的项目是由 XML 这个文件的,事实上,当我在 XML 里自定义方法的时候,也可以正常调用,问题在于,mybatisplus 应该提供给我事先设置好的方法,但当我调用他们的时候,总是会报错我的问题,主要在这里
    montaro2017
        10
    montaro2017  
       2024-10-04 20:45:37 +08:00
    你的 BaseService 全名是什么?
    tiRolin
        11
    tiRolin  
    OP
       2024-10-04 21:04:51 +08:00
    @montaro2017 是 com.example.common.mybatis.service.BaseService;
    因为这个是我公司提供的依赖,这里我用 example 我替代掉了公司的依赖路径包名
    BaseService 中的源码我不能给你看,但是他的类是如下所示
    public class BaseService<M extends BaseMapper<T>, T> extends ServiceImpl<M, T> {
    public BaseService() {
    }
    // ...略
    }
    其中略的代码内容是提供了分页、插入、删除方法
    我最初也考虑过可能是因为该依赖并没有提供 count 方法导致的 bug ,但是后面当我跳过 count 方法直接调用 insert 方法时也照样报这个异常,所以我认为原因应该不是该依赖没有提供 count 方法这么简单,问题可能是在其他地方导致的
    montaro2017
        12
    montaro2017  
       2024-10-04 21:41:30 +08:00
    @tiRolin #11 你在这里打个断点看看有没有执行,你的 BaseService 不会是从公司项目里拷进来的吧,我感觉你可能少拷了什么
    tiRolin
        13
    tiRolin  
    OP
       2024-10-04 22:15:03 +08:00
    @montaro2017 我在您说的地方打了断点,并没有执行,我的 BaseService 是从公司仓库里拉取到我的项目中的,具体到 pom 文件的代码是
    <dependency>
    <groupId>com.example.base</groupId>
    <artifactId>base-core</artifactId>
    <version>${com.example.version}</version>
    </dependency>
    <dependency>
    <groupId>com.example.common</groupId>
    <artifactId>common-redis</artifactId>
    <version>${com.example.version}</version>
    </dependency>
    我觉得我应该没缺少什么内容,当然也可能真缺少了,但是我现在也不确定,因为我还没搞懂这个问题到底是为什么而产生的
    night98
        14
    night98  
       2024-10-05 08:00:22 +08:00
    long count = this.count(queryWrapper);

    改成
    long count = this.baseTestUserMapper.count(queryWrapper);
    试试,你这个问题应该就是楼上说的,你的 BaseService 有问题,导致他是直接去执行 mapper 的方法,然后提示找不到映射方法,或者你把这个 BaseService 换成 mybatis plus 的继承 service 也可以
    montaro2017
        15
    montaro2017  
       2024-10-05 10:31:52 +08:00
    @tiRolin #13 mybatis plus 的内置方法是通过注入实现的,count 方法没注入当然会报错,我认为你也没必要一定得继承 BaseService 吧,先继承 ServiceImpl 看下正不正常
    tiRolin
        16
    tiRolin  
    OP
       2024-10-05 13:24:59 +08:00
    @night98 不行,我试了下仍然报这个异常,我使用 IService 的方式来实现接口也同样报这个问题
    tiRolin
        17
    tiRolin  
    OP
       2024-10-05 13:26:31 +08:00
    @montaro2017 我试了下,通过 IService 的方式来实现接口也同样报这个异常,我的意思是我通过在 Service 接口中继承 IService ,然后构建一个 Service 实现类,这个实现类继承 ServiceImpl 的方式来实现方法调用,也是同样报这个问题
    night98
        18
    night98  
       2024-10-05 21:15:45 +08:00   1
    @tiRolin #16 你还要检查一下你的 BaseTestUserMapper 是否继承的是来自于 mybatis plus 的 BaseMapper ,必须要两者统一才行,如果是用的你公司的依赖,那么他可能是用的其他的方式实现的
    Edaa
        19
    Edaa  
       2024-10-06 22:47:00 +08:00   1
    用下下面的依赖试一下?
    ```xml
    <dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.6</version>
    <exclusions>
    <exclusion>
    <artifactId>mybatis-spring</artifactId>
    <groupId>org.mybatis</groupId>
    </exclusion>
    </exclusions>
    </dependency>
    <dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis-spring</artifactId>
    <version>3.0.3</version>
    </dependency>
    ```
    montaro2017
        20
    montaro2017  
       2024-10-07 15:21:48 +08:00   1
    @tiRolin #17 你先把引入的依赖去掉,在使用 ServiceImpl 试试
    tiRolin
        21
    tiRolin  
    OP
       2024-10-07 17:04:44 +08:00
    @montaro2017 我解决这个问题了,问题的原因是 SpringBoot3 的版本一旦配合使用内嵌的 mybatis3 就会导致这个错误,解决这个错误的方法是将 springboot 的版本降级为 3.1.6 同时引入下面的两个依赖
    <dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.3</version>
    </dependency>

    <dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-core</artifactId>
    <version>3.5.3</version>
    </dependency>
    就可以完美解决该问题,之所以之前迟迟解决不了是因为一直怀疑是我的自己的配置出了问题,没想到问题是直接出在依赖上,这个依赖组合是存在未修复的 Bug 的
    tiRolin
        22
    tiRolin  
    OP
       202410-07 17:04:56 +08:00
    @Edaa 我解决这个问题了,问题的原因是 SpringBoot3 的版本一旦配合使用内嵌的 mybatis3 就会导致这个错误,解决这个错误的方法是将 springboot 的版本降级为 3.1.6 同时引入下面的两个依赖
    <dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.3</version>
    </dependency>

    <dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-core</artifactId>
    <version>3.5.3</version>
    </dependency>
    就可以完美解决该问题,之所以之前迟迟解决不了是因为一直怀疑是我的自己的配置出了问题,没想到问题是直接出在依赖上,这个依赖组合是存在未修复的 Bug 的
    tiRolin
        23
    tiRolin  
    OP
       2024-10-07 17:05:08 +08:00
    @night98 我解决这个问题了,问题的原因是 SpringBoot3 的版本一旦配合使用内嵌的 mybatis3 就会导致这个错误,解决这个错误的方法是将 springboot 的版本降级为 3.1.6 同时引入下面的两个依赖
    <dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.5.3</version>
    </dependency>

    <dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-core</artifactId>
    <version>3.5.3</version>
    </dependency>
    就可以完美解决该问题,之所以之前迟迟解决不了是因为一直怀疑是我的自己的配置出了问题,没想到问题是直接出在依赖上,这个依赖组合是存在未修复的 Bug 的
    RedBeanIce
        24
    RedBeanIce  
       2024-10-07 21:53:33 +08:00
    在 springboot2 中,一般是你的 myabtis plus config 出了问题。
    WilliamZeyar
        25
    WilliamZeyar  
       358 天前
    springboot3 mybatis-plus 依赖问题,可以升级 mybatis-plus 到 3.5.7 版本,去掉其他 mybatis 依赖,我就是这么解决的。
    <dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-spring-boot3-starter</artifactId>
    <version>3.5.7</version>
    </dependency>
    WilliamZeyar
        26
    WilliamZeyar  
       358 天前
    我的 springboot 版本是 3.3.3 mybatis-plus 版本 3.5.7
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     905 人在线   最高记录 6679       Seect Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 27ms UTC 19:32 PVG 03:32 LAX 12:32 JFK 15:32
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86