一、MyBatis 与 MyBatis-Plus 概述
1. MyBatis
MyBatis 是一款优秀的持久层框架,它消除了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的操作。其核心思想是通过 XML 或注解 将 SQL 语句与 Java 方法映射,实现 SQL 与业务逻辑的分离,同时支持自定义 SQL、存储过程和高级映射。
2. MyBatis-Plus(MP)
MyBatis-Plus 是 MyBatis 的增强工具(只做增强,不做改变),在 MyBatis 基础上简化了开发流程,提供了一系列开箱即用的功能(如 CRUD 接口、条件构造器等),无需编写重复 SQL,大幅提升开发效率。
二、核心功能对比
三、架构关系图(示意图描述)
四、代码示例对比
1. 基础 CRUD 操作
MyBatis 实现:
需手动编写 Mapper 接口和 XML 映射文件。
- 实体类 User.java
public class User {
private Long id;
private String name;
private Integer age;
// getter/setter
}
- Mapper 接口 UserMapper.java
public interface UserMapper {
// 查询所有用户
List<User> selectAll();
// 新增用户
int insert(User user);
// 根据 ID 删除
int deleteById(Long id);
}
- XML 映射文件 UserMapper.xml
<mapper namespace="com.example.mapper.UserMapper">
<!-- 查询所有 -->
<select id="selectAll" resultType="com.example.entity.User">
SELECT id, name, age FROM user
</select>
<!-- 新增 -->
<insert id="insert" parameterType="com.example.entity.User">
INSERT INTO user (name, age) VALUES (#{name}, #{age})
</insert>
<!-- 删除 -->
<delete id="deleteById" parameterType="java.lang.Long">
DELETE FROM user WHERE id = #{id}
</delete>
</mapper>
MyBatis-Plus 实现:
继承 BaseMapper 接口,无需编写 SQL。
o Mapper 接口 UserMapper.java
public interface UserMapper extends BaseMapper<User> {
// 无需写方法,BaseMapper 已包含 selectList()、insert()、deleteById() 等
}
- 调用示例
@Autowired
private UserMapper userMapper;
// 查询所有
List<User> userList = userMapper.selectList(null);
// 新增
User user = new User();
user.setName("张三");
user.setAge(20);
userMapper.insert(user);
// 根据 ID 删除
userMapper.deleteById(1L);
2. 条件查询
MyBatis 实现:
需用动态 SQL 标签拼接条件。
oXML 映射文件新增
<select id="selectByCondition" parameterType="map" resultType="User">
SELECT id, name, age 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 链式组装条件。
// 查询:name 包含"张"且 age > 18 的用户
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
queryWrapper.like("name", "张") // LIKE '%张%'
.gt("age", 18); // age > 18
List<User> userList = userMapper.selectList(queryWrapper);
3. 分页查询
MyBatis 实现(需集成 PageHelper):
// 配置 PageHelper 插件(省略配置类)
PageHelper.startPage(1, 10); // 第1页,每页10条
List<User> userList = userMapper.selectAll();
Page<User> page = (Page<User>) userList;
MyBatis-Plus 实现:
// 1. 配置分页插件(Spring Boot 配置类)
@Configuration
public class MyBatisPlusConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
// 添加分页插件
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
return interceptor;
}
}
// 2. 分页查询
Page<User> page = new Page<>(1, 10); // 第1页,每页10条
IPage<User> userPage = userMapper.selectPage(page, null);
List<User> records = userPage.getRecords(); // 数据列表
long total = userPage.getTotal(); // 总条数
五、总结
o MyBatis:灵活性高,适合需要高度自定义 SQL 的场景,但需编写大量重复代码。
o MyBatis-Plus:在 MyBatis 基础上简化开发,提供丰富的增强功能,适合快速开发(尤其是 CRUD 密集型业务)。
实际开发中,两者可无缝结合:简单操作用 MP 简化,复杂 SQL 仍可通过 MyBatis 的 XML/注解实现。