关于mybatis-plus配置xml映射路径不生效原因

项目中遇到Mybatis-Plus的增删改查接口不生效,问题可能涉及Mapper注解、namespace设置、方法名匹配、parameterType指定和配置文件等。解决方案包括检查@MapperScan的包名,确保mapper.java和mapper.xml的namespace与方法ID一致,明确xml的parameterType,以及正确配置数据库连接信息。
摘要由CSDN通过智能技术生成

项目场景:

接口自测过程中发现mybatis-plus 增删改查不生效


问题描述

Springboot项目中,在mybatis中mapper数据库操作接口(有的称DAO,有的直接说mapper,都只同一文件)与mapper配置文件在做映射绑定的时候出现问题,简单说,就是接口与xml要么是找不到,要么是找到了却匹配不到

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

原因分析:

1.是否mapper.java文件上使用了注解@Mapper  或者 在启动类上扫描了Mapper类 @MapperScan("com.heima.model.mappers")   【注意扫描的包名是否正确】

2.注意mapper.xml文件中的namespace是否正确指向到Mapper.java类的位置 【<mapper namespace="com.heima.model.mappers.app.ApUserArticleListMapper">】

3.注意被调用的方法名在mapper.java中和mapper.xml中的id保持一致性

4.注意mapper.xml方法的parameterType尽量指定全路径的domain

5.注意Mapper.java在被调用的地方需要注入@Autowired


解决方案:

首先在创建的项目pom文件中添加maven依赖,如下:

 <dependency>
     <groupId>mysql</groupId>
     <artifactId>mysql-connector-java</artifactId>
 </dependency>
 <dependency>
     <groupId>com.baomidou</groupId>
     <artifactId>mybatis-plus-boot-starter</artifactId>
     <version>3.4.2</version>
 </dependency>
 

然后在application配置文件填上连接mysql的配置项,大致如下:

spring.datasource.password=
spring.datasource.username=
spring.datasource.url=
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

按照常规书写xml就行行了,最关键的配置是下面一项:

 在idea中创建resources下面的文件夹时,千万不能“偷懒”,像创建类一样用xx.xx.xx的方式快速创建包结构。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java-version

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值