mybatis/mybatisPlus Update操作返回值问题简述

 

int的返回值类型

 

Mybatis 进行 update 操作得到的 int 返回值并不是影响的行数 .如图,这里面所写的2 row in set指的是记录的匹配条数,而不是操作影响的记录数.

 

 

如何设置update返回为受影响条数

 

 通过对 JDBC URL 显式的指定 useAffectedRows 选项(通常就在jdbc url配置的最后加上下面这段就OK了)

jdbc:mysql://${jdbc.host}/${jdbc.db}?useAffectedRows=true

 

 

### MyBatis 使用注解开发的具体步骤 #### 1. 添加依赖 确保项目的 `pom.xml` 文件中已引入 MyBatis 的相关依赖。通常情况下,Spring Boot 或 Maven 项目需要以下依赖: ```xml <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.3.0</version> </dependency> ``` 以上代码片段展示了如何通过 Maven 引入 MyBatis 及其 Spring Boot Starter[^1]。 --- #### 2. 创建 Mapper 接口 定义一个接口作为数据访问层 (DAO),并使用注解来描述 SQL 查询逻辑。例如: ```java import org.apache.ibatis.annotations.*; import java.util.List; public interface UserMapper { @Select("SELECT * FROM users WHERE id = #{id}") User findById(int id); // 根据 ID 查找用户 @Insert("INSERT INTO users(name, age) VALUES(#{name}, #{age})") int insertUser(User user); // 插入新用户 @Update("UPDATE users SET name=#{name}, age=#{age} WHERE id=#{id}") int updateUser(User user); // 更新用户信息 @Delete("DELETE FROM users WHERE id=#{id}") int deleteUserById(int id); // 删除指定 ID 用户 } ``` 上述代码展示了一个典型的 MyBatis 注解开发中的 DAO 层设计,其中包含了增删改查的操作方法[^2]。 --- #### 3. 配置 Mapper 扫描路径 在 MyBatis 的核心配置文件或者 Spring Boot 中启用自动扫描功能。可以通过 XML 方式或 Java 配置类实现。 ##### 方法一:XML 配置 在 MyBatis 的全局配置文件 (`mybatis-config.xml`) 中添加如下内容: ```xml <mappers> <package name="com.example.mapper"/> </mappers> ``` 此部分用于告知 MyBatis 自动加载指定包下的所有 Mapper 接口[^1]。 ##### 方法二:Java 配置类 如果使用的是 Spring Boot,则可以在主程序启动类或其他配置类中标记 `@MapperScan` 注解: ```java import org.springframework.context.annotation.Configuration; import org.mybatis.spring.annotation.MapperScan; @Configuration @MapperScan(basePackages = "com.example.mapper") // 替换为实际的 Mapper 路径 public class MyBatisConfig { } ``` 这种方式更适用于现代框架集成场景下,减少手动维护 XML 文件的工作量[^3]。 --- #### 4. 测试验证 完成上述配置后,可通过单元测试验证注解的功能是否正常工作。例如,在 JUnit 测试类中调用 `findById()` 方法获取一条记录,并断言返回值是否符合预期。 ```java @SpringBootTest class UserMapperTest { @Autowired private UserMapper userMapper; @Test void testFindById() { User user = userMapper.findById(1); assertNotNull(user); assertEquals("John Doe", user.getName()); } } ``` 该示例说明了如何利用 Spring Boot 提供的支持机制运行简单的 CRUD 功能测试案例[^1]。 --- ### 注意事项 - **冲突检测**:同一个功能不能同时存在注解和 XML 配置,否则可能导致 MyBatis 抛出异常提示重复映射错误。 - **适用范围**:对于复杂的动态 SQL 场景建议优先考虑 XML 开发模式;而对于较为固定的简单查询则推荐采用注解形式以提升效率。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值