MyBatis-Plus (opens new window)(简称 MP)是一个 MyBatis (opens new window)的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
(下图来源于官网)
即使你没有使用或学习过 Mybatis,也没关系。这不会妨碍你对 MybatisPlus 的学习,使用过后你会感受到它的强大之处,它帮我们简化了很多代码的逻辑。
以下是我使用 MybatisPlus 过程中发现的一些强大特性。
实现元对象处理器接口:com.baomidou.mybatisplus.core.handlers.MetaObjectHandler,这样我们就可以对指定字段进行填充入库。
在配置类里面用 Bean 来注入一个方法返回 PaginationInterceptor这个类对象。这样就可以非常容易的实现分页功能。
在配置类里面用 Bean 来注入一个方法返回 OptimisticLockerInterceptor 这个类对象。这样我们就可以解决丢失更新的问题。
在配置类里面用 Bean 来注入一个方法返回 ISqlInjector 这个类对象。这样我们就可以实现逻辑删除的逻辑。
在配置类里面用 Bean 来注入一个方法返回 PerformanceInterceptor这个类对象。这样我们可以通过设置参数:maxTime,sql 执行最大时长,超过自动停止运行,有助于发现问题。
通过创建 QueryWrapper 类对象,可以去构建我们想要的不同查询条件的组合,快速的实现各种复杂查询条件的生成。
以下是代码结构示意图:
@EnableTransactionManagement
@Configuration
@MapperScan("com.test.mpdemo0112.mapper")//在 Spring Boot 启动类中添加 @MapperScan 注解,扫描 Mapper 文件夹
public class MybatisPlusConfig {
//乐观锁插件
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor(){
return new OptimisticLockerInterceptor();
}
//分页插件
@Bean
public PaginationInterceptor paginationInterceptor(){
return new PaginationInterceptor();
}
//逻辑删除插件
@Bean
public ISqlInjector iSqlInjector(){
return new LogicSqlInjector();
}
//SQL 执行性能分析插件
//(1)参数说明
//参数:maxTime:SQL 执行最大时长,超过自动停止运行,有助于发现问题。
//参数:format:SQL是否格式化,默认false
@Bean
@Profile({"test","dev"})
public PerformanceInterceptor performanceInterceptor(){
PerformanceInterceptor performanceInterceptor = new PerformanceInterceptor();
performanceInterceptor.setMaxTime(500);//ms,超过此处设置的ms则sql不执行
performanceInterceptor.setFormat(true);
return performanceInterceptor;
}
}
application.properties里面指定了使用哪个环境的配置文件。