写点什么

Mybatis-plus 在项目中的应用

作者:Rubble
  • 2022 年 4 月 20 日
  • 本文字数:1744 字

    阅读完需:约 6 分钟

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;       }
复制代码


  1. 逻辑删除,全局配置之后,再也不用管逻辑删除字段了。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;
复制代码


  1. 自动填充。妈妈再也不用管 create_time,update_time 了。默认注入字段值为 null 时才会注入,即手动设置值后不再注入。特别注意 beanUtil.copy 时的值问题。

  2. 可以从 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)       }   }
复制代码


  1. 乐观锁,直接应用比较少,针对特别情景,部分接口会做 version 处理。


   @Bean   public MybatisPlusInterceptor mybatisPlusInterceptor() {       MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();       interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());       return interceptor;   }
复制代码


   @Version   private Integer version;
复制代码


  1. 多数据源。有时会用,通过注解去切换数据源

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

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

  4. 查询 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);
复制代码


用户头像

Rubble

关注

还未添加个人签名 2021.06.01 加入

还未添加个人简介

评论

发布
暂无评论
Mybatis-plus在项目中的应用_4月日更_Rubble_InfoQ写作社区