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 {
    @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条
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的复杂场景。两者完全兼容,可根据项目需求灵活选择。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值