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

MyBatis与MyBatis-Plus区别

一、框架定位与核心差异

1.1 框架定

  • MyBatis:一款优秀的半自动化持久层框架,专注于SQL灵活性,需手动编写SQL语句和结果映射。
  • MyBatis-Plus(MP):MyBatis的增强工具,在MyBatis基础上只做增强不做改变,旨在简化开发、提高效率。

1.2 核心差异对比

特性MyBatisMyBatis-Plus
CRUD操作需手动编写XML或注解SQL内置通用Mapper/Service,零SQL实现CRUD
条件构造需手动拼接动态SQL(如<if>标签)提供QueryWrapper/LambdaQueryWrapper
分页功能需集成第三方插件(如PageHelper)内置物理分页插件,配置后直接使用
代码生成无内置工具内置代码生成器,支持生成全层代码
主键策略需手动配置支持4种主键策略(含分布式ID生成器)
全局拦截需自定义插件内置全表删除/更新阻断,预防误操作

二、实例代码对比

2.1 基础CRUD操作

MyBatis实现

1. Mapper接口

public interface UserMapper {User selectById(Long id);int insert(User user);int updateById(User user);int deleteById(Long id);
}

2. XML映射文件

<mapper namespace="com.example.mapper.UserMapper"><select id="selectById" resultType="User">SELECT * FROM user WHERE id = #{id}</select><insert id="insert" parameterType="User">INSERT INTO user(name, age) VALUES (#{name}, #{age})</insert><!-- 更新/删除类似 -->
</mapper>
MyBatis-Plus实现

1. Mapper接口(仅需继承BaseMapper)

public interface UserMapper extends BaseMapper<User> {// 无需编写方法,直接继承BaseMapper的CRUD方法
}

2. 调用示例

@Autowired
private UserMapper userMapper;// 查询
User user = userMapper.selectById(1L);// 新增
User newUser = new User();
newUser.setName("张三");
newUser.setAge(20);
userMapper.insert(newUser);// 更新
user.setAge(21);
userMapper.updateById(user);// 删除
userMapper.deleteById(1L);

2.2 条件查询

MyBatis实现(XML动态SQL)
<select id="selectByCondition" parameterType="Map" resultType="User">SELECT * FROM user<where><if test="name != null">AND name LIKE CONCAT('%', #{name}, '%')</if><if test="age != null">AND age > #{age}</if></where>
</select>
MyBatis-Plus实现(条件构造器)
// 普通方式
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.like("name", "张").gt("age", 18);
List<User> userList = userMapper.selectList(queryWrapper);// Lambda方式(避免字段名硬编码)
LambdaQueryWrapper<User> lambdaQuery = new LambdaQueryWrapper<>();
lambdaQuery.like(User::getName, "张").gt(User::getAge, 18);
List<User> userList = userMapper.selectList(lambdaQuery);

2.3 分页查询

MyBatis实现(需集成PageHelper)
// 配置PageHelper插件
PageHelper.startPage(1, 10);
List<User> userList = userMapper.selectAll();
PageInfo<User> pageInfo = new PageInfo<>(userList);
MyBatis-Plus实现(内置分页插件)

1. 配置分页插件

@Configuration
public class MyBatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;}
}

2. 使用分页

Page<User> page = new Page<>(1, 10); // 第1页,每页10条
Page<User> resultPage = userMapper.selectPage(page, null);
List<User> userList = resultPage.getRecords();
long total = resultPage.getTotal(); // 总记录数

三、高级特性对比

3.1 主键自动生成

  • MyBatis:需手动配置@GeneratedValue或XML中的useGeneratedKeys
  • MyBatis-Plus:支持4种策略(如雪花算法),通过注解快速配置:
    @TableId(type = IdType.ASSIGN_ID) // 雪花算法ID
    private Long id;
    

3.2 逻辑删除

  • MyBatis:需手动在SQL中添加WHERE deleted=0
  • MyBatis-Plus:通过注解自动实现逻辑删除:
    @TableLogic // 逻辑删除字段(0-未删,1-已删)
    private Integer deleted;
    

3.3 代码生成器

  • MyBatis:无内置工具,需借助第三方插件。
  • MyBatis-Plus:内置代码生成器,支持生成Entity、Mapper、Service、Controller:
    AutoGenerator mpg = new AutoGenerator();
    // 配置数据源、包路径、策略等
    mpg.execute(); // 生成全层代码
    

四、使用场景建议

优先选择MyBatis-Plus的场景

  • 快速开发的中小项目,需减少重复SQL编写。
  • 单表CRUD操作频繁,需提高开发效率。
  • 需要内置分页、逻辑删除等通用功能。

优先选择MyBatis的场景

  • 复杂SQL场景(如多表关联、存储过程),需完全控制SQL。
  • 已有MyBatis项目且无升级必要。
  • 对框架轻量化有严格要求。

五、总结

MyBatis-Plus在MyBatis基础上提供了通用CRUD、条件构造器、分页插件等增强功能,大幅减少样板代码,适合快速开发;而MyBatis更适合需要高度自定义SQL的复杂场景。两者完全兼容,可根据项目需求灵活选择。

http://www.dtcms.com/a/390400.html

相关文章:

  • 数据血缘探秘:用SQL串联不同数据源的脉络
  • 多线程程序性能优化:缓存命中率与伪共享深度剖析
  • Spring Boot支持哪些类型的自定义配置文件?
  • uniapp:scss变量使用方法
  • postman接口测试系列: 时间戳和加密
  • 模型蒸馏demo
  • 【JVM】Java中有哪些垃圾回收算法?
  • 为何楼宇自控系统日益受欢迎?解析其兴起的核心动因
  • ASP.NET Core RazorPages/MVC/Blazor/Razor/WebApi概念记录说明
  • .NET Core 中 RabbitMQ 和 MassTransit 的使用
  • 使用QT进行3D开发建模
  • 阿里云开源DeepResearch:轻量化AI推理框架技术解析与实践指南
  • Visual Studio 2026 Insiders 重磅发布:AI 深度集成、性能飞跃、全新设计
  • 大模型初识(基础模型 业务集成+智能体Agent+Prompt提示词优化)
  • 【4/20】Node.js 入门:设置后端服务器,实现一个简单 API 端点
  • Kafka事务:构建可靠的分布式消息处理系统
  • 补环境-JS原型链检测:在Node.js中完美模拟浏览器原型环境
  • TCP端口号的作用
  • 笔记本电脑维修指南(芯片级)
  • Burpsuite进行暴力破解
  • 虚拟现实CAVE系统中的光学跟踪技术,1:1呈现CAD模型沉浸式交互
  • 2025拍照手机综合排名与场景化选购指南
  • TCP 抓包分析:tcp抓包工具、 iOS/HTTPS 流量解析全流程
  • 从电商API到数据分析的全流程教程
  • 【踩坑】ELK日志解析优化实战:解决多行合并与字段提取问题
  • 大数据高校舆情分析系统 snownlp情感分析 数据分析 可视化 Flask框架 大数据实战(源码)✅
  • 【12/20】数据库高级查询:MongoDB 聚合管道在用户数据分析中的应用,实现报告生成
  • Oceanbase tablegroup表组与负载均衡实践
  • 什么是批量剪辑矩阵源码,支持OEM!
  • RabbitMQ快速入门指南