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方法重载和方法重写的区别到底在哪?
Jun 11 Java/Android
Java实现斗地主之洗牌发牌
Jun 14 Java/Android
分析设计模式之模板方法Java实现
Jun 23 Java/Android
详解Java分布式事务的 6 种解决方案
Jun 26 Java/Android
使用springMVC所需要的pom配置
Sep 15 Java/Android
Java Spring 控制反转(IOC)容器详解
Oct 05 Java/Android
Java 实战项目之家居购物商城系统详解流程
Nov 11 Java/Android
SpringDataJPA实体类关系映射配置方式
Dec 06 Java/Android
SpringBoot2零基础到精通之数据与页面响应
Mar 22 Java/Android
SpringCloud项目如何解决log4j2漏洞
Apr 10 Java/Android
Java处理延时任务的常用几种解决方案
Jun 01 Java/Android
SpringBoot项目部署到阿里云服务器的实现步骤
Jun 28 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处理Oracle的CLOB实例
2014/11/03 PHP
浅谈关于JavaScript的语言特性分析
2013/04/11 Javascript
自定义ExtJS控件之下拉树和下拉表格附源码
2013/10/15 Javascript
javascript删除字符串最后一个字符
2014/01/14 Javascript
使用documentElement正确取得当前可见区域的大小
2014/07/25 Javascript
JQuery中使用.each()遍历元素学习笔记
2014/11/08 Javascript
js中substr,substring,indexOf,lastIndexOf,split,replace的用法详解
2015/11/09 Javascript
通过Tabs方法基于easyUI+bootstrap制作工作站
2016/03/28 Javascript
jQuery实现大图轮播
2017/02/13 Javascript
JavaScript上传文件时不用刷新页面方法总结(推荐)
2017/08/15 Javascript
element ui 对话框el-dialog关闭事件详解
2018/02/26 Javascript
VUE接入腾讯验证码功能(滑块验证)备忘
2019/05/07 Javascript
QML实现圆环颜色选择器
2019/09/25 Javascript
javscript 数组扁平化的实现
2020/02/03 Javascript
uniapp与webview之间的相互传值的实现
2020/06/29 Javascript
[11:01]2014DOTA2西雅图邀请赛 冷冷带你探秘威斯汀
2014/07/08 DOTA
Python面向对象思想与应用入门教程【类与对象】
2019/04/12 Python
Python实现个人微信号自动监控告警的示例
2019/07/03 Python
python移位运算的实现
2019/07/15 Python
TensorFlow自定义损失函数来预测商品销售量
2020/02/05 Python
Python3实现监控新型冠状病毒肺炎疫情的示例代码
2020/02/13 Python
Python网络爬虫信息提取mooc代码实例
2020/03/06 Python
Python操作Excel工作簿的示例代码(\*.xlsx)
2020/03/23 Python
Python 在函数上添加包装器
2020/07/28 Python
pandas针对excel处理的实现
2021/01/15 Python
Michael Kors澳大利亚官网:世界知名的奢侈饰品和成衣设计师
2020/02/13 全球购物
汽车技术服务与营销专业在籍生自荐信
2013/09/28 职场文书
创业计划书六个要素
2013/12/26 职场文书
旷课检讨书3000字
2014/02/04 职场文书
田径运动会通讯稿
2014/09/13 职场文书
党支部班子“四风”问题自我剖析材料
2014/09/28 职场文书
2015年基层党支部工作总结
2015/05/21 职场文书
医护人员继续教育学习心得体会
2016/01/19 职场文书
《棉鞋里的阳光》教学反思
2016/02/20 职场文书
MySQL中InnoDB存储引擎的锁的基本使用教程
2021/05/26 MySQL
浅析MySQL如何实现事务隔离
2021/06/26 MySQL