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


Posted in Java/Android onJuly 01, 2021

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

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

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

分页插件

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

// 最新版
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.H2));
        return interceptor;
    }

逻辑删除

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

自动填充

妈妈再也不用管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)
    }
}

乐观锁

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

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

@Version
private Integer version;

多数据源

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

通用枚举

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

id生成及主键

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

查询 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);

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

Java/Android 相关文章推荐
如何解决springcloud feign 首次调用100%失败的问题
Jun 23 Java/Android
Java Dubbo框架知识点梳理
Jun 26 Java/Android
spring项目中切面及AOP的使用方法
Jun 26 Java/Android
解决SpringBoot跨域的三种方式
Jun 26 Java/Android
SpringBoot整合JWT的入门指南
Jun 29 Java/Android
mybatis3中@SelectProvider传递参数方式
Aug 04 Java/Android
Java基础——Map集合
Apr 01 Java/Android
Dubbo+zookeeper搭配分布式服务的过程详解
Apr 03 Java/Android
Java Lambda表达式常用的函数式接口
Apr 07 Java/Android
Java 超详细讲解ThreadLocal类的使用
Apr 07 Java/Android
详解Flutter网络请求Dio库的使用及封装
Apr 14 Java/Android
SpringBoot项目多数据源及mybatis 驼峰失效的问题解决方法
Jul 07 Java/Android
SpringBoot 拦截器妙用你真的了解吗
解决SpringBoot文件上传临时目录找不到的问题
java实现对Hadoop的操作
Jul 01 #Java/Android
解决MultipartFile.transferTo(dest) 报FileNotFoundExcep的问题
Jul 01 #Java/Android
Java中多线程下载图片并压缩能提高效率吗
分析ZooKeeper分布式锁的实现
Java并发编程必备之Future机制
You might like
咖啡知识 除了喝咖啡还有那些知识点
2021/03/06 新手入门
JAVA/JSP学习系列之二
2006/10/09 PHP
php操作xml并将其插入数据库的实现方法
2016/09/08 PHP
PHP删除二维数组中相同元素及数组重复值的方法示例
2017/05/05 PHP
PHP 中使用explode()函数切割字符串为数组的示例
2017/05/06 PHP
Laravel框架源码解析之入口文件原理分析
2020/05/14 PHP
JavaScript CSS修改学习第二章 样式
2010/02/19 Javascript
Jquery替换已存在于element上的event的方法
2010/03/09 Javascript
JQuery操作tr和td内容的方法实例
2013/03/06 Javascript
Javascript实现滑块滑动改变值的实现代码
2013/04/12 Javascript
JavaScript前补零操作实例
2015/03/11 Javascript
jQuery取消ajax请求的方法
2015/06/09 Javascript
关于动态执行代码(js的Eval)实例详解
2016/08/15 Javascript
javascript淘宝主图放大镜功能
2016/10/20 Javascript
完美解决UI-Grid表格元素中多个空格显示为一个空格的问题
2017/04/25 Javascript
使用layui 渲染table数据表格的实例代码
2018/08/19 Javascript
解决vue-cli项目打包出现空白页和路径错误的问题
2018/09/04 Javascript
vue插件实现v-model功能
2018/09/10 Javascript
react+redux仿微信聊天界面
2019/06/21 Javascript
nuxt框架中对vuex进行模块化设置的实现方法
2019/09/06 Javascript
ant design vue嵌套表格及表格内部编辑的用法说明
2020/10/28 Javascript
浅谈vant组件Picker 选择器选单选问题
2020/11/04 Javascript
Python显示进度条的方法
2014/09/20 Python
总结Python中逻辑运算符的使用
2015/05/13 Python
Python制作简易注册登录系统
2016/12/15 Python
Python异常处理操作实例详解
2018/08/28 Python
Python设计模式之代理模式实例详解
2019/01/19 Python
对python文件读写的缓冲行为详解
2019/02/13 Python
对PyQt5的输入对话框使用(QInputDialog)详解
2019/06/25 Python
加拿大快时尚零售商:Ardene
2018/02/14 全球购物
JMS中Topic和Queue有什么区别
2013/05/15 面试题
上课迟到检讨书100字
2014/01/11 职场文书
大学校园生活自我鉴定
2014/01/13 职场文书
校园会短篇的广播稿
2014/10/21 职场文书
个人催款函范文
2015/06/23 职场文书
解决SpringCloud Feign传对象参数调用失败的问题
2021/06/23 Java/Android