好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

Mybatis-plus在项目中的简单应用

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

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

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

分页插件

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

?

1

2

3

4

5

6

7

// 最新版

     @Bean

     public MybatisPlusInterceptor mybatisPlusInterceptor() {

         MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();

         interceptor.addInnerInterceptor( new PaginationInnerInterceptor(DbType.H2));

         return interceptor;

     }

逻辑删除

全局配置之后,再也不用管逻辑删除字段了。xml中自定义sql需要自己处理逻辑字段

?

1

2

3

4

5

6

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)

?

1

2

@TableLogic

private Integer deleted;

自动填充

妈妈再也不用管create_time,update_time了。默认注入字段值为null时才会注入,即手动设置值后不再注入。特别注意beanUtil.copy时的值问题。
可以从header、shiro、Security 中获取当前用户信息,更新createUser,updateUser

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

@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)

     }

}

乐观锁

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

?

1

2

3

4

5

6

7

8

9

@Bean

public MybatisPlusInterceptor mybatisPlusInterceptor() {

     MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();

     interceptor.addInnerInterceptor( new OptimisticLockerInnerInterceptor());

     return interceptor;

}

 

@Version

private Integer version;

多数据源

有时会用,通过注解去切换数据源。参考文章:MyBatis-Plus实现多数据源的示例代码

通用枚举

通过@EnumValue标记值,将数据库中的枚举值转换没枚举类型,可以少做一步转换。参考文章:Mybatis-Plus通用枚举的使用详解

id生成及主键

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

查询 LambdaQueryWrapper

?

1

2

3

4

5

6

7

List<User> list = userService.list(Wrappers.<User>lambdaQuery()

.eq(User::getUserName, "123" )

)

 

List<User> list = userService.lambdaQuery()

.eq(User::getUserName, "123" )

.list();

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

?

1

2

3

LambdaQueryWrapper queryWrapper = Wrappers.<User>lambdaQuery()

.eq(User::getUserName, "123" );

User user = userService.getOne(queryWrapper, false );

到此这篇关于Mybatis-plus在项目中的简单应用的文章就介绍到这了,更多相关Mybatis-plus项目应用内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

原文链接:https://juejin.cn/post/6979021737740468232

查看更多关于Mybatis-plus在项目中的简单应用的详细内容...

  阅读:19次