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 相关文章推荐
IDEA使用SpringAssistant插件创建SpringCloud项目
Jun 23 Java/Android
Feign调用全局异常处理解决方案
Jun 24 Java/Android
Java实现多文件上传功能
Jun 30 Java/Android
解决SpringBoot文件上传临时目录找不到的问题
Jul 01 Java/Android
浅谈sql_@SelectProvider及使用注意说明
Aug 04 Java/Android
springboot中的pom文件 project报错问题
Jan 18 Java/Android
Java实现给Word文件添加文字水印
Feb 15 Java/Android
SpringBoot整合minio快速入门教程(代码示例)
Apr 03 Java/Android
Spring Boot项目传参校验的最佳实践指南
Apr 05 Java/Android
Java 获取Word中所有的插入和删除修订的方法
Apr 06 Java/Android
详解Android中的TimePickerView(时间选择器)的用法
Apr 30 Java/Android
SpringBoot接入钉钉自定义机器人预警通知
Jul 15 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 setcookie设置Cookie用法(及设置无效的问题)
2011/07/13 PHP
深入file_get_contents函数抓取内容失败的原因分析
2013/06/25 PHP
php模板原理讲解
2013/11/13 PHP
如何阻止网站被恶意反向代理访问(防网站镜像)
2014/03/18 PHP
列举PHP的Yii 2框架的开发优势
2015/07/03 PHP
Prototype1.5 rc2版指南最后一篇之Position
2007/01/10 Javascript
JavaScript在IE和FF下的兼容性问题
2014/05/19 Javascript
jquery图片切换插件
2015/03/16 Javascript
JavaScript设计模式经典之命令模式
2016/02/24 Javascript
jQuery实现HTML表格单元格的合并功能
2016/04/06 Javascript
js检测离开或刷新页面时表单数据是否更改的方法
2016/08/02 Javascript
javascript简单进制转换实现方法
2016/11/24 Javascript
微信页面倒计时代码(解决safari不兼容date的问题)
2016/12/13 Javascript
浅析上传头像示例及其注意事项
2016/12/14 Javascript
使用jquery datatable和bootsrap创建表格实例代码
2017/03/17 Javascript
js es6系列教程 - 新的类语法实战选项卡(详解)
2017/09/02 Javascript
详解Vue2 SSR 缓存 Api 数据
2017/11/20 Javascript
Vue 仿QQ左滑删除组件功能
2018/03/12 Javascript
jQuery中的类名选择器(.class)用法简单示例
2018/05/14 jQuery
基于Vue实现可以拖拽的树形表格实例详解
2018/10/18 Javascript
vue-iview动态新增和删除的方法
2020/06/17 Javascript
vue3.0 自适应不同分辨率电脑的操作
2021/02/06 Vue.js
[00:36]DOTA2勇士令状莱恩声望物品——冥晶之厄展示
2018/05/25 DOTA
[48:54]VGJ.T vs infamous Supermajor小组赛D组败者组第一轮 BO3 第二场 6.3
2018/06/04 DOTA
Python编程中对文件和存储器的读写示例
2016/01/25 Python
python3 动态模块导入与全局变量使用实例
2019/12/22 Python
python实现按日期归档文件
2021/01/30 Python
纯CSS3实现自定义Tooltip边框涂鸦风格的教程
2014/11/05 HTML / CSS
html5开发之viewport使用
2013/10/17 HTML / CSS
美国女士泳装店:Swimsuits For All
2017/03/02 全球购物
.NET面试问题集
2015/12/08 面试题
业务员薪酬管理制度
2014/01/15 职场文书
大学生职业生涯规划书汇总
2014/03/20 职场文书
个人授权委托书范本
2014/09/14 职场文书
2016年学校党支部公开承诺书
2016/03/25 职场文书
销区经理年终述职报告模板
2019/11/28 职场文书