当前位置: 首页 > news >正文

mybatis过渡到mybatis-plus过程中需要注意的地方

将 MyBatis 升级为 MyBatis-Plus(简称 MP)是一个平滑过渡的过程,因为 MP 是 MyBatis 的增强工具(而非替代),但仍有一些关键注意事项需要关注,以确保升级后功能兼容且能充分利用 MP 的特性:

1. 依赖管理与版本兼容

  • 替换依赖:移除原 MyBatis 的依赖(如mybatismybatis-spring),引入 MyBatis-Plus 的核心依赖(mybatis-plus-boot-starter 或 mybatis-plus)。
    示例(Maven):
    <!-- 移除旧依赖 -->
    <dependency><groupId>org.mybatis</groupId><artifactId>mybatis-spring</artifactId>
    </dependency><!-- 引入MP依赖 -->
    <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.3.1</version> <!-- 选择稳定版本,需与Spring Boot版本兼容 -->
    </dependency>
    
  • 版本兼容:确保 MP 版本与 Spring Boot、数据库驱动(如 MySQL Connector)兼容(参考 MP 官方文档的版本适配表)。

2. 核心配置调整

  • SqlSessionFactory 配置
    原 MyBatis 的SqlSessionFactory需替换为 MP 的MybatisSqlSessionFactoryBean(自动集成 MyBatis 的功能,同时添加 MP 增强)。
    若使用 Spring Boot,默认自动配置可无需手动修改;若手动配置,需调整:
    // 旧配置(MyBatis)
    // SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();// 新配置(MP)
    MybatisSqlSessionFactoryBean sessionFactory = new MybatisSqlSessionFactoryBean();
    
  • 全局配置:MP 支持全局配置(如主键策略、驼峰命名映射等),可通过MybatisConfiguration或配置文件(application.yml)设置,替代原 MyBatis 的mybatis-config.xml部分配置。
    示例(YAML):
    mybatis-plus:configuration:map-underscore-to-camel-case: true # 驼峰命名映射(默认开启)global-config:db-config:id-type: AUTO # 全局主键策略(需与数据库主键生成策略匹配)
    

3. Mapper 接口与 XML 适配

  • 继承 BaseMapper:MP 的BaseMapper<T>提供了 CRUD 通用方法(如selectByIdinsert),原有 Mapper 接口可继承它以减少重复代码:

    // 旧:自定义CRUD方法
    public interface UserMapper {User selectById(Long id);int insert(User user);
    }// 新:继承BaseMapper,直接使用通用方法(可保留自定义方法)
    public interface UserMapper extends BaseMapper<User> {// 保留原自定义方法(如复杂查询)List<User> selectByAge(int age);
    }
    

    注意:若原有方法名与BaseMapper冲突(如selectById),需确保逻辑一致,或重命名自定义方法。

  • XML 映射文件
    原有 XML 文件可直接复用,但需注意:

    • 避免与BaseMapper的通用方法重复(如无需再写selectById的 XML 实现);
    • MP 的条件构造器(QueryWrapper)可替代部分动态 SQL,减少 XML 复杂度。

4. 实体类注解适配

MP 通过注解实现实体与数据库表的映射,需在原有实体类上添加必要注解:

  • @TableName("t_user"):指定数据库表名(若类名与表名不一致);
  • @TableId(type = IdType.AUTO):指定主键字段及生成策略(需与全局配置或数据库策略匹配);
  • @TableField("user_name"):指定字段名(若属性名与字段名不一致,或排除非表字段@TableField(exist = false))。

示例:

@TableName("t_user") // 表名
public class User {@TableId(type = IdType.AUTO) // 主键自增private Long id;@TableField("user_name") // 字段名映射private String userName;@TableField(exist = false) // 非表字段private String tempData;
}

5. 插件与扩展功能适配

  • 分页插件:MP 自带分页插件(MybatisPlusInterceptor),替代原 MyBatis 的 PageHelper 等插件,需单独配置:

    java

    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); // 分页插件return interceptor;
    }
    
  • 其他插件:如乐观锁插件(OptimisticLockerInnerInterceptor)、防 SQL 注入插件等,需根据业务需求配置,注意与原有插件的兼容性。

6. 代码生成器与逆向工程

若使用逆向工程生成代码,建议替换为 MP 的AutoGenerator,可一键生成实体、Mapper、Service 等代码,并自动添加 MP 注解和继承关系,减少手动适配成本。

7. 兼容性与测试

  • 自定义 SQL 检查:原有自定义 SQL(尤其是动态 SQL)需测试是否与 MP 兼容,避免因 MP 的 SQL 解析逻辑导致异常。
  • 事务与缓存:MP 完全兼容 MyBatis 的事务管理和缓存机制(一级缓存、二级缓存),但需确认缓存配置是否生效。
  • 批量操作:MP 提供IService接口的批量方法(如saveBatch),性能优于循环单条操作,可逐步替换原有批量逻辑。

8. 避免过度依赖 MP 特性

MP 的增强功能(如条件构造器、通用 CRUD)可提高开发效率,但复杂业务逻辑仍建议使用自定义 SQL,避免因过度依赖框架导致 SQL 可读性下降。

总结

升级的核心是 **“增强而非重构”**:通过替换依赖、调整配置、适配注解,保留原有业务逻辑的同时,逐步引入 MP 的通用功能和插件。关键是确保版本兼容、测试覆盖,并根据团队情况逐步迁移,充分利用 MP 简化开发的优势。

http://www.xdnf.cn/news/1359019.html

相关文章:

  • 《Distilling the Knowledge in a Neural Network》论文PDF分享, 2015 年,谷歌提出了 “知识蒸馏” 的概念
  • 06 - spring security角色和权限设置
  • vulnhub-billu_b0x靶机渗透
  • GPT-5国内免费体验
  • k8s下的网络通信之calico与调度
  • sqlite创建数据库,创建表,插入数据,查询数据的C++ demo
  • 最新sa-token的oauth2封装免密和密码登录
  • 【高等数学】第十章 重积分——第一节 二重积分的概念与性质
  • MinIO03-Linux安装
  • Docker安装RocketMQ
  • 征程 6X 常用工具介绍
  • AI大模型应用开发面试:深入解析技术点
  • 每日算法题【链表】:相交链表、环形链表、环形链表II
  • 鸿蒙中点击完成时延分析
  • LeetCode 42.接雨水
  • response对象的elapsed属性
  • Elasticsearch Ruby 客户端故障排查实战指南
  • Bright Data MCP:突破AI数据获取限制的革命性工具
  • 阿里云 OSS 前端直传实战:表单上传 + Policy 模式详解
  • GD32VW553-IOT 测评和vscode开发环境搭建
  • 硬件开发_基于物联网的宠物猫饲养系统
  • 互联网大厂Java面试模拟:核心技术点深度解析
  • 极验demo(float)(二)
  • 从字节码层面剖析以太坊智能合约创建原理
  • EXCEL实现复制后倒序粘贴
  • 从Android到鸿蒙:一场本应无缝的转型-优雅草卓伊凡
  • iptables 防火墙核心知识梳理(附实操指南)
  • 【文献阅读】Land degradation drivers of anthropogenic sand and dust storms
  • 《一次高并发场景下疑难Bug的深度排查与复盘》
  • rust语言 (1.88) egui (0.32.1) 学习笔记(逐行注释)(十七)设置主题