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 相关文章推荐
SpringBoot集成Redis,并自定义对象序列化操作
Jun 22 Java/Android
idea以任意顺序debug多线程程序的具体用法
Aug 30 Java/Android
详解Java七大阻塞队列之SynchronousQueue
Sep 04 Java/Android
Java网络编程之UDP实现原理解析
Sep 04 Java/Android
关于springboot配置druid数据源不生效问题(踩坑记)
Sep 25 Java/Android
Spring中的使用@Async异步调用方法
Nov 01 Java/Android
spring注解 @PropertySource配置数据源全流程
Mar 25 Java/Android
springboot入门 之profile设置方式
Apr 04 Java/Android
Java 多态分析
Apr 26 Java/Android
Java 轮询锁使用时遇到问题
May 11 Java/Android
Java实现带图形界面的聊天程序
Jun 10 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
PHP 程序授权验证开发思路
2009/07/09 PHP
php连接mssql的一些相关经验及注意事项
2013/02/05 PHP
解析yahoo邮件用phpmailer发送的实例
2013/06/24 PHP
php 字符串压缩方法比较示例
2014/01/23 PHP
Cygwin中安装PHP方法步骤
2015/07/04 PHP
Yii框架数据模型的验证规则rules()被执行的方法
2016/12/02 PHP
PHP数组与字符串互相转换实例
2020/05/05 PHP
动态为事件添加js代码示例
2009/02/15 Javascript
node.js 一个简单的页面输出实现代码
2012/03/07 Javascript
js数组与字符串的相互转换方法
2014/07/09 Javascript
js中使用replace方法完成某个字符的转换
2014/08/20 Javascript
jquery+ajax请求且带返回值的代码
2015/08/12 Javascript
jquery京东商城双11焦点图多图广告特效代码分享
2015/09/06 Javascript
简单讲解jQuery中的子元素过滤选择器
2016/04/18 Javascript
通过JS获取Request.QueryString()参数的值实现方法
2016/09/27 Javascript
JavaScript中apply方法的应用技巧小结
2016/09/29 Javascript
jfinal与bootstrap的登出实战详解
2017/11/27 Javascript
微信小程序实现点击文字页面跳转功能【附源码下载】
2017/12/12 Javascript
Electron + vue 打包桌面操作流程详解
2019/06/24 Javascript
Element ui 下拉多选时新增一个选择所有的选项
2019/08/21 Javascript
Vue中引入svg图标的两种方式
2021/01/14 Vue.js
[04:22]DOTA2大事件之护国神翼
2020/08/14 DOTA
python实现通过pil模块对图片格式进行转换的方法
2015/03/24 Python
Python selenium 父子、兄弟、相邻节点定位方式详解
2016/09/15 Python
python tkinter组件摆放方式详解
2019/09/16 Python
jupyter notebook 重装教程
2020/04/16 Python
如何从csv文件构建Tensorflow的数据集
2020/09/21 Python
让IE6支持css3,让 IE7、IE8 都支持CSS3
2011/10/09 HTML / CSS
Moda Italia荷兰:意大利男士服装
2019/08/31 全球购物
电子商务专业推荐信范文
2013/12/02 职场文书
实用的简历自我评价
2014/03/06 职场文书
名人演讲稿范文
2014/09/16 职场文书
堂吉诃德读书笔记
2015/06/30 职场文书
优秀乡村医生事迹材料(2016精选版)
2016/02/29 职场文书
Golang全局变量加锁的问题解决
2021/05/08 Golang
VUE解决跨域问题Access to XMLHttpRequest at
2022/05/06 Vue.js