MyBatisPlus与MyBatis的对比与联系
MyBatisPlus是一个强大的MyBatis增强工具,它继承了MyBatis的所有特性,同时还引入了一些新的特性,如自动填充、乐观锁插件、逻辑删除等。通过使用MyBatisPlus,开发人员可以大大减少手写SQL的工作量,提高开发效率。
前言
在Java世界中,我们经常处理的一个问题就是如何有效地与数据库进行交互。对此,许多不同的框架和库已经被开发出来,包括广为人知的MyBatis。然而,MyBatis虽然功能强大,但在实际使用中,我们常常需要写大量的XML配置和DAO代码,这无疑增加了开发的复杂性。这时,一个名为MyBatisPlus的库闯入了我们的视线。那么,MyBatisPlus是什么?它与MyBatis有什么区别和联系?本文将详细地解答这些问题。
1. MyBatisPlus简介
MyBatisPlus(简称MP)是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做改变,为简化开发、提高效率而生。它引入了一些新的特性,如自动填充、乐观锁插件、逻辑删除等,同时还内置了一些常用的CRUD操作,极大地减少了开发人员的工作量。
2. MyBatisPlus与MyBatis的联系
MyBatisPlus是基于MyBatis的,因此,它们之间存在着紧密的联系。MyBatisPlus继承了MyBatis的所有特性,包括动态SQL、SQL注入器、分页插件等。同时,MyBatisPlus还兼容MyBatis的所有配置和使用习惯,使得开发人员可以无缝地从MyBatis迁移到MyBatisPlus。
3. MyBatisPlus与MyBatis的区别
虽然MyBatisPlus基于MyBatis,但它并非只是MyBatis的复制品。MyBatisPlus在MyBatis的基础上做了很多增强和优化,使得它在某些方面超过了MyBatis。以下是MyBatisPlus与MyBatis的主要区别:
1. 无需手写SQL
在MyBatis中,如果我们需要执行CRUD操作,通常需要手动编写SQL语句。而在MyBatisPlus中,我们可以直接调用内置的方法来完成这些操作,而无需手动编写SQL。例如,我们可以使用BaseMapper
接口中的insert
、selectById
、updateById
和deleteById
方法来完成插入、查询、更新和删除操作。
User user = new User();
user.setName("John");
user.setEmail("john@example.com");
// 插入操作,无需手写SQL
userMapper.insert(user);
// 查询操作,无需手写SQL
User userFromDb = userMapper.selectById(user.getId());
// 更新操作,无需手写SQL
userFromDb.setAge(31);
userMapper.updateById(userFromDb);
// 删除操作,无需手写SQL
userMapper.deleteById(userFromDb.getId());
MyBatisPlus 提供了 IService 接口,这个接口封装了一些常见的 CRUD 操作,比如 save()
, remove()
, update()
, list()
等等。如果你的 service 类实现了这个接口,那么你就可以直接在 service 类中调用这些方法,而不需要再去调用 mapper 的方法。这样可以使得你的 service 类更加简洁,也更加符合面向对象的设计原则。
例如:
@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IUserService {
// ...
}
// 在 controller 或其他地方使用
@Autowired
private IUserService userService;
public void someMethod() {
User user = new User();
user.setName("John");
user.setEmail("john@example.com");
// 直接调用 service 的方法,而不需要调用 mapper 的方法
userService.save(user);
}
而在 MyBatis 中,你通常需要在 service 类中注入 mapper,然后通过调用 mapper 的方法来进行数据库操作,例如:
@Service
public class UserServiceImpl implements IUserService {
private final UserMapper userMapper;
public UserServiceImpl(UserMapper userMapper) {
this.userMapper = userMapper;
}
// ...
public void someMethod() {
User user = new User();
user.setName("John");
user.setEmail("john@example.com");
// 需要调用 mapper 的方法来进行数据库操作
userMapper.insert(user);
}
}
2. 自动填充功能
MyBatisPlus支持自动填充功能,我们可以通过在实体类中使用@TableField(fill = FieldFill.INSERT)
和@TableField(fill = FieldFill.UPDATE)
注解来指定哪些字段需要在插入或更新时自动填充。
public class User implements Serializable {
// ...
@TableField(fill = FieldFill.INSERT)
private Date createTime;
@TableField(fill = FieldFill.UPDATE)
private Date updateTime;
// ...
}
3. 乐观锁插件
MyBatisPlus内置了乐观锁插件,我们可以通过在实体类中使用@Version
注解来指定哪个字段作为乐观锁字段。
public class User implements Serializable {
// ...
@Version
private Integer version;
// ...
}
然后在更新时,MyBatisPlus会自动将版本号加一,并在更新语句中添加版本号的判断条件。
4. 逻辑删除
MyBatisPlus支持逻辑删除,我们可以通过在实体类中使用@TableLogic
注解来指定哪个字段作为逻辑删除字段。
public class User implements Serializable {
// ...
@TableLogic
private Integer deleted;
// ...
}
然后在执行删除操作时,MyBatisPlus会自动将逻辑删除字段的值更新为删除标记,而不是真正地删除记录。
5. 性能分析插件
MyBatisPlus内置了性能分析插件,我们可以通过配置该插件来启用SQL性能分析。
@Configuration
public class MybatisPlusConfig {
@Bean
public PerformanceInterceptor performanceInterceptor() {
PerformanceInterceptor performanceInterceptor = new PerformanceInterceptor();
// 设置SQL性能分析的最大时间,如果超过这个时间,则不执行
performanceInterceptor.setMaxTime(1000);
// 设置SQL格式化
performanceInterceptor.setFormat(true);
return performanceInterceptor;
}
}
然后该插件会自动输出每条SQL语句的执行时间,如果超过设定的最大时间,则不执行该SQL。
4. MyBatisPlus的使用示例
下面,我们将通过一个简单的例子来演示如何使用MyBatisPlus。假设我们有一个用户表(user),现在我们想要实现对该表的CRUD操作。
首先,我们需要创建一个User实体类:
import com.baomidou.mybatisplus.annotation.*;
import java.io.Serializable;
import java.util.Date;
public class User implements Serializable {
private static final long serialVersionUID = 1L;
@TableId(value = "id", type = IdType.AUTO)
private Long id;
private String name;
private Integer age;
private String email;
@TableField(fill = FieldFill.INSERT)
private Date createTime;
@TableField(fill = FieldFill.UPDATE)
private Date updateTime;
@Version
private Integer version;
@TableLogic
private Integer deleted;
// getters and setters...
}
然后,我们需要创建一个UserMapper接口:
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
public interface UserMapper extends BaseMapper<User> {
}
最后,我们就可以使用MyBatisPlus进行CRUD操作了:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public void crudOperations() {
// 创建一个新用户
User user = new User();
user.setName("John");
user.setAge(30);
user.setEmail("john@example.com");
userMapper.insert(user);
// 查询用户
User userFromDb = userMapper.selectById(user.getId());
System.out.println(userFromDb);
// 更新用户
userFromDb.setAge(31);
userMapper.updateById(userFromDb);
// 删除用户
userMapper.deleteById(userFromDb.getId());
}
}
5. 结论
MyBatisPlus是一个强大的MyBatis增强工具,它继承了MyBatis的所有特性,同时还引入了一些新的特性,如自动填充、乐观锁插件、逻辑删除等。通过使用MyBatisPlus,开发人员可以大大减少手写SQL的工作量,提高开发效率。如果你正在使用MyBatis,那么不妨试试MyBatisPlus,相信它会给你带来全新的开发体验。
👉 💐🌸 公众号请关注 "果酱桑", 一起学习,一起进步! 🌸💐
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)