SpringBoot - Mybatis-Plus
概述
JPA:ORM规范,实现由ORM框架实现
Hibernate:ORM框架,灵活,比较重,单表很爽
Mybatis:持久层框架,轻量,可以自己写SQL
Mybatis-Plus:MyBatis 增强,只做增强不做改变,简化开发、提高效率
这几款一比较,还是选择了 Mybatis-Plus 。
组件
Mybatis-Plus: 官网 使用说明
依赖
pom.xml
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.3.1.tmp</version>
</dependency>
配置
字段自动填充配置
@Slf4j
@Component
public class FieldFillConfig implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
this.setFieldValByName("createtime", new Date(), metaObject);
this.setFieldValByName("updatetime", new Date(), metaObject);
}
@Override
public void updateFill(MetaObject metaObject) {
this.setFieldValByName("updatetime", new Date(), metaObject);
}
}
乐观锁、多租户配置
@Configuration
public class MybatisPlusConfig {
// 乐观锁,配合 @Version 使用。
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
// 多租户配置
// 可在Mapper上配置@SqlParser(filter=true)取消多租户过滤
@Bean
public PaginationInterceptor paginationInterceptor() {
PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
/*
* 【测试多租户】 SQL 解析处理拦截器<br> 这里固定写成住户 1 实际情况你可以从cookie读取,因此数据看不到 【 麻花藤 】 这条记录(
* 注意观察 SQL )<br>
*/
List<ISqlParser> sqlParserList = new ArrayList<>();
TenantSqlParser tenantSqlParser = new TenantSqlParser();
tenantSqlParser.setTenantHandler(new TenantHandler() {
@Override
public Expression getTenantId(boolean where) {
// 该 where 条件 3.2.0 版本开始添加的,用于分区是否为在 where 条件中使用
// 如果是in/between之类的多个tenantId的情况,参考下方示例
return new LongValue(1L);
}
@Override
public String getTenantIdColumn() {
return "zone";
}
@Override
public boolean doTableFilter(String tableName) {
// 这里可以判断是否过滤表
/*
* if ("user".equals(tableName)) { return true; }
*/
return false;
}
});
sqlParserList.add(tenantSqlParser);
paginationInterceptor.setSqlParserList(sqlParserList);
paginationInterceptor.setSqlParserFilter(new ISqlParserFilter() {
@Override
public boolean doFilter(MetaObject metaObject) {
// MappedStatement ms = SqlParserHelper.getMappedStatement(metaObject);
// // 过滤自定义查询此时无租户信息约束【 麻花藤 】出现
// if
// ("com.baomidou.springboot.mapper.UserMapper.selectListBySQL".equals(ms.getId()))
// {
// return true;
// }
return false;
}
});
return paginationInterceptor;
}
}