Mybatis-plus在项目中的应用

举报
琴岛蛏子 发表于 2022/03/21 00:09:51 2022/03/21
【摘要】 Mybatis-plus在项目中的应用本文是一篇随笔,记录项目中应用的一些情景。Mybatis-plus是Spring框架中OOM的一大利器,其简单易用参考官网文档即可很快上手。https://mp.baomidou.com/guide/p6spy 执行 SQL 分析打印,只需加入依赖,加入配置文件即可有完美的sql打印。有性能损耗线上不能使用分页插件,只需注入插件即可,实在太方便了有没有...

Mybatis-plus在项目中的应用

本文是一篇随笔,记录项目中应用的一些情景。

Mybatis-plus是Spring框架中OOM的一大利器,其简单易用参考官网文档即可很快上手。https://mp.baomidou.com/guide/

  1. p6spy 执行 SQL 分析打印,只需加入依赖,加入配置文件即可有完美的sql打印。有性能损耗线上不能使用

  2. 分页插件,只需注入插件即可,实在太方便了有没有。

    // 最新版
        @Bean
        public MybatisPlusInterceptor mybatisPlusInterceptor() {
            MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
            interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.H2));
            return interceptor;
        }
    
  3. 逻辑删除,全局配置之后,再也不用管逻辑删除字段了。xml中自定义sql需要自己处理逻辑字段

    mybatis-plus:
      global-config:
        db-config:
          logic-delete-field: flag  # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2)
          logic-delete-value: 1 # 逻辑已删除值(默认为 1)
          logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)
    
    @TableLogic
    private Integer deleted;
    
  4. 自动填充。妈妈再也不用管create_time,update_time了。默认注入字段值为null时才会注入,即手动设置值后不再注入。特别注意beanUtil.copy时的值问题。

    可以从header、shiro、Security 中获取当前用户信息,更新createUser,updateUser

    @Slf4j
    @Component
    public class MyMetaObjectHandler implements MetaObjectHandler {
    
        @Override
        public void insertFill(MetaObject metaObject) {
            log.info("start insert fill ....");
            this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐使用)
          String user = "anonymous";
          // 从header shiro security中获取user信息
            this.strictInsertFill(metaObject, "createUser", String.class, user); 
        }
    
        @Override
        public void updateFill(MetaObject metaObject) {
            log.info("start update fill ....");
            this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐)
          String user = "anonymous";
          // 从header shiro security中获取user信息
          this.strictUpdateFill(metaObject, "updateUser", String.class, user);
            // 或者
            this.strictUpdateFill(metaObject, "updateTime", () -> LocalDateTime.now(), LocalDateTime.class); // 起始版本 3.3.3(推荐)
            // 或者
            this.fillStrategy(metaObject, "updateTime", LocalDateTime.now()); // 也可以使用(3.3.0 该方法有bug)
        }
    }
    
  5. 乐观锁,直接应用比较少,针对特别情景,部分接口会做version处理。

    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
        return interceptor;
    }
    
    @Version
    private Integer version;
    
  6. 多数据源。有时会用,通过注解去切换数据源

  7. 通用枚举 通过@EnumValue标记值,将数据库中的枚举值转换没枚举类型,可以少做一步转换。

  8. id生成及主键。分布式服务基本基于业务去切分数据库,一个微服务基本对应一个库,对大部分应用不需要做分表的情景,bigint自增id够用。

  9. 查询 LambdaQueryWrapper

    List<User> list = userService.list(Wrappers.<User>lambdaQuery()
    .eq(User::getUserName,"123")
    )
    
    List<User> list = userService.lambdaQuery()
    .eq(User::getUserName,"123")
    .list();
    

    逻辑唯一时查询一个值,false 当有多个值是不会抛出异常。

    LambdaQueryWrapper queryWrapper = Wrappers.<User>lambdaQuery()
    .eq(User::getUserName,"123");
    User user = userService.getOne(queryWrapper,false);
    
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。