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

MyBatis与MyBatis-Plus深度分析

MyBatis与MyBatis-Plus深度分析

一、MyBatis原理与基础

1. MyBatis核心原理

MyBatis是一个半自动ORM框架,主要原理包括:

  • SQL与代码分离:通过XML或注解配置SQL语句
  • 动态SQL:提供if、choose、foreach等标签实现动态SQL
  • 结果集映射:将数据库结果集自动映射到Java对象
  • 一级/二级缓存:提供缓存机制提高性能

2. MyBatis基础知识点

核心组件

  • SqlSessionFactory:创建SqlSession的工厂
  • SqlSession:执行SQL的核心接口
  • Mapper接口:定义数据库操作方法
  • Mapper XML:编写SQL语句的配置文件

关键特性

  • 参数映射(#{}, ${})
  • 结果映射(resultMap)
  • 动态SQL标签
  • 插件机制

3. MyBatis简单案例

// Mapper接口
public interface UserMapper {@Select("SELECT * FROM users WHERE id = #{id}")User getUserById(int id);@Insert("INSERT INTO users(name, email) VALUES(#{name}, #{email})")@Options(useGeneratedKeys = true, keyProperty = "id")void insertUser(User user);
}// 实体类
public class User {private Integer id;private String name;private String email;// getters/setters
}// 使用示例
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
try (SqlSession session = sqlSessionFactory.openSession()) {UserMapper mapper = session.getMapper(UserMapper.class);User user = mapper.getUserById(1);System.out.println(user.getName());
}

二、MyBatis-Plus原理与增强

1. MyBatis-Plus核心原理

MyBatis-Plus在MyBatis基础上增强:

  • 自动CRUD:内置通用Mapper,减少基础SQL编写
  • 条件构造器:通过Lambda表达式构建查询条件
  • 代码生成器:自动生成Entity、Mapper等代码
  • 分页插件:简化分页操作
  • 性能分析插件:输出SQL执行性能

2. MyBatis-Plus基础知识点

核心特性

  • 通用CRUD操作
  • Lambda表达式查询
  • 主键策略支持
  • 全局配置
  • 乐观锁支持
  • SQL注入器

与MyBatis主要区别

特性MyBatisMyBatis-Plus
CRUD操作需手动编写内置通用方法
条件构造需写SQLLambda表达式
代码生成需第三方工具内置生成器
分页需插件内置分页插件
性能分析需配置内置插件

3. MyBatis-Plus简单案例

// 实体类
@Data
@TableName("users")
public class User {@TableId(type = IdType.AUTO)private Long id;private String name;private String email;
}// Mapper接口
public interface UserMapper extends BaseMapper<User> {// 已继承基本CRUD方法
}// 服务层
@Service
public class UserService {@Autowiredprivate UserMapper userMapper;public List<User> getUsersByName(String name) {QueryWrapper<User> queryWrapper = new QueryWrapper<>();queryWrapper.lambda().eq(User::getName, name);return userMapper.selectList(queryWrapper);}
}// 使用Lambda查询
List<User> users = userMapper.selectList(Wrappers.<User>lambdaQuery().like(User::getName, "张").gt(User::getAge, 18)
);

三、综合对比与选择建议

1. 适用场景

  • MyBatis适用场景
    • 需要精细控制SQL
    • 复杂查询和存储过程调用
    • 已有MyBatis项目维护
  • MyBatis-Plus适用场景
    • 快速开发CRUD功能
    • 需要减少样板代码
    • 新项目开发

2. 性能考虑

  • MyBatis-Plus在简单CRUD上效率更高(减少代码量)
  • 复杂SQL场景两者性能相当(最终都转为MyBatis执行)
  • MyBatis-Plus的Lambda查询会转换为MyBatis的SQL,无额外性能损耗

3. 综合案例展示

复杂查询+分页案例

// MyBatis实现
@Select("SELECT * FROM users WHERE name LIKE #{name} AND age > #{age} LIMIT #{offset}, #{size}")
List<User> findUsers(@Param("name") String name, @Param("age") int age,@Param("offset") int offset,@Param("size") int size);// MyBatis-Plus实现
Page<User> page = new Page<>(1, 10); // 第1页,每页10条
LambdaQueryWrapper<User> wrapper = Wrappers.lambdaQuery();
wrapper.like(User::getName, "张").gt(User::getAge, 18);
IPage<User> userPage = userMapper.selectPage(page, wrapper);

动态更新案例

// MyBatis实现
@Update("<script>" +"UPDATE users " +"<set>" +"  <if test='name != null'>name=#{name},</if>" +"  <if test='email != null'>email=#{email},</if>" +"</set>" +"WHERE id=#{id}" +"</script>")
void updateUserSelective(User user);// MyBatis-Plus实现
userMapper.update(null, Wrappers.lambdaUpdate(User.class).set(User::getName, "新名字").eq(User::getId, 1));

四、总结

  1. MyBatis提供更精细的SQL控制,适合复杂场景
  2. MyBatis-Plus大幅简化CRUD操作,提高开发效率
  3. 两者可以结合使用,MyBatis-Plus处理简单操作,复杂SQL仍可用原生MyBatis方式
  4. 新项目推荐使用MyBatis-Plus,可显著减少样板代码

根据项目需求和团队熟悉程度选择合适的框架,大型项目中也可以两者混合使用,兼顾开发效率和灵活性

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

相关文章:

  • SimpleAdmin云服务器发布
  • Qt —— 在Windows10下通过在线安装方式安装Qt6.9.0(附:“server replied: Forbidden“网络出错解决办法)
  • Pytorch张量和损失函数
  • 电子科技浪潮下的华秋电子:慕尼黑上海电子展精彩回顾
  • 反转链表II
  • mysql常用方法
  • 关于Go语言的开发环境的搭建
  • 组合问题(多条件)
  • Linux 系统安全基线检查:入侵防范测试标准与漏洞修复方法
  • C语言| 静态局部变量
  • 3级-运算符
  • 从数据中台到数据飞轮:实现数据驱动的升级之路
  • 论文学习_Trex: Learning Execution Semantics from Micro-Traces for Binary Similarity
  • SparkSQL入门指南:从基础到实践的全面解析
  • 配置Nginx启用Https
  • 豌豆 760 收录泛滥现象深度解析与应对策略
  • FedTracker:为联邦学习模型提供所有权验证和可追溯性
  • Unity3D 序列化机制:引擎内的应用场景和基本原理
  • vue3项目创建-配置-elementPlus导入-路由自动导入
  • 江苏发改委回复:分时电价调整对储能项目的影响 源网荷储一体化能量管理系统储能EMS
  • 为什么企业建站或独立站选用WordPress
  • C程序的存储空间分配
  • 汉得 x 真味生物|H-ZERO PaaS项目启动,共启数字化新征程!
  • 可视化+智能补全:用Database Tool重塑数据库工作流
  • java 结合 FreeMarker 和 Docx4j 来生成包含图片的 docx 文件
  • 七、深入 Hive DDL:管理表、分区与洞察元数据
  • 邀请函|PostgreSQL培训认证报名正式开启
  • 演员评论家算法
  • LS-DYNA一箭穿心仿真分析
  • Oracle CDB 与 Non-CDB (NoCDB) 的区别