SpringBoot - Mybatis-Plus

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;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值