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 相关文章推荐
Java 将PPT幻灯片转为HTML文件的实现思路
Jun 11 Java/Android
Springboot如何使用logback实现多环境配置?
Jun 16 Java/Android
SpringBoot集成Redis,并自定义对象序列化操作
Jun 22 Java/Android
Java中PriorityQueue实现最小堆和最大堆的用法
Jun 27 Java/Android
Java基础之线程锁相关知识总结
Jun 30 Java/Android
Java基础之详解HashSet的使用方法
Jun 30 Java/Android
新手初学Java网络编程
Jul 07 Java/Android
Java中CyclicBarrier和CountDownLatch的用法与区别
Aug 23 Java/Android
SpringBoot中使用Redis作为全局锁示例过程
Mar 24 Java/Android
Dubbo+zookeeper搭配分布式服务的过程详解
Apr 03 Java/Android
Java死锁的排查
May 11 Java/Android
SpringBoot Http远程调用的方法
Aug 14 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
全国FM电台频率大全 - 1 北京市
2020/03/11 无线电
基于php实现长连接的方法与注意事项的问题
2013/05/10 PHP
PHP中防止SQL注入方法详解
2014/12/25 PHP
微信支付PHP SDK之微信公众号支付代码详解
2015/12/09 PHP
php实现爬取和分析知乎用户数据
2016/01/26 PHP
php弹出提示框的是实例写法
2019/09/26 PHP
PHP封装请求类实例分析【基于Yii框架】
2019/10/17 PHP
JS cookie中文乱码解决方法
2014/01/28 Javascript
jQuery循环滚动新闻列表示例代码
2014/06/17 Javascript
js锁屏解屏通过对$.ajax进行封装实现
2014/07/31 Javascript
Bootstrap基本插件学习笔记之按钮(21)
2016/12/08 Javascript
20行JS代码实现粘贴板复制功能
2018/02/06 Javascript
解决mpvue + vuex 开发微信小程序vuex辅助函数mapState、mapGetters不可用问题
2018/08/03 Javascript
npm scripts 使用指南详解
2018/10/08 Javascript
jquery实现垂直无限轮播的方法分析
2019/07/16 jQuery
vue实现简单计算商品价格
2020/09/14 Javascript
[47:04]LGD vs infamous Supermajor小组赛D组 BO3 第二场 6.3
2018/06/04 DOTA
python模拟新浪微博登陆功能(新浪微博爬虫)
2013/12/24 Python
python命令行参数sys.argv使用示例
2014/01/28 Python
Python标准库defaultdict模块使用示例
2015/04/28 Python
python用pickle模块实现“增删改查”的简易功能
2017/06/07 Python
pyqt5 lineEdit设置密码隐藏,删除lineEdit已输入的内容等属性方法
2019/06/24 Python
Django用户认证系统 User对象解析
2019/08/02 Python
python读取dicom图像示例(SimpleITK和dicom包实现)
2020/01/16 Python
学习python需要有编程基础吗
2020/06/02 Python
python实现感知机模型的示例
2020/09/30 Python
使用CSS3编写灰阶滤镜来制作黑白照片效果的方法
2016/05/09 HTML / CSS
英国在线滑雪板和冲浪商店:The Board Basement
2020/01/11 全球购物
英国第一的滑雪服装和装备零售商:Snow+Rock
2020/02/01 全球购物
优质飞蝇钓和渔具:RiverBum
2020/05/10 全球购物
进程的查看和调度分别使用什么命令
2015/03/25 面试题
师范生教师实习自我鉴定
2013/09/27 职场文书
《鸿门宴》教学反思
2014/04/22 职场文书
建筑节能汇报材料
2014/08/22 职场文书
明星邀请函
2015/02/02 职场文书
Mysql 如何合理地统计一个数据库里的所有表的数据量
2022/04/18 MySQL