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 18 Java/Android
Spring Boot 实现敏感词及特殊字符过滤处理
Jun 29 Java/Android
关于springboot 配置date字段返回时间戳的问题
Jul 25 Java/Android
使用logback实现按自己的需求打印日志到自定义的文件里
Aug 30 Java/Android
JavaWeb实现显示mysql数据库数据
Mar 19 Java/Android
springboot+zookeeper实现分布式锁
Mar 21 Java/Android
SpringBoot中使用Redis作为全局锁示例过程
Mar 24 Java/Android
java后台调用接口及处理跨域问题的解决
Mar 24 Java/Android
Java工作中实用的代码优化技巧分享
Apr 21 Java/Android
SpringBoot项目部署到阿里云服务器的实现步骤
Jun 28 Java/Android
IDEA中sout快捷键无效问题的解决方法
Jul 23 Java/Android
spring boot实现文件上传
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
PHP define函数的使用说明
2008/08/27 PHP
php学习笔记 数组的常用函数
2011/06/13 PHP
php页面防重复提交方法总结
2013/11/25 PHP
Yii基于CActiveForm的Ajax数据验证用法示例
2016/07/14 PHP
使用Yii2实现主从数据库设置
2016/11/20 PHP
PHP基于pdo的数据库操作类【可支持mysql、sqlserver及oracle】
2018/05/21 PHP
PHP接口类(interface)的定义、特点和应用示例
2020/05/18 PHP
求解开jscript.encode代码的asp函数
2007/02/28 Javascript
Javascript倒计时代码
2010/08/12 Javascript
JQuery1.4+ Ajax IE8 内存泄漏问题
2010/10/15 Javascript
jQuery仿Excel表格编辑功能的实现代码
2013/05/01 Javascript
JS实现闪动的title消息提醒效果
2014/06/20 Javascript
JS右下角广告窗口代码(可收缩、展开及关闭)
2015/09/04 Javascript
JavaScript中字面量与函数的基本使用知识
2015/10/20 Javascript
利用JS屏蔽页面中的Enter按键提交表单的方法
2016/11/25 Javascript
学习 NodeJS 第八天:Socket 通讯实例
2016/12/21 NodeJs
前端构建工具之gulp的语法教程
2017/06/12 Javascript
11行JS代码制作二维码生成功能
2018/03/09 Javascript
使用ECharts实现状态区间图
2018/10/25 Javascript
JavaScript定时器使用方法详解
2020/03/26 Javascript
JS 图片压缩原理与实现方法详解
2020/04/29 Javascript
ubuntu上安装python的实例方法
2019/09/30 Python
详解Ubuntu环境下部署Django+uwsgi+nginx总结
2020/04/02 Python
python函数map()和partial()的知识点总结
2020/05/26 Python
canvas 阴影和图形变换的示例代码
2018/01/02 HTML / CSS
英国家用电器购物网站:Hughes
2018/02/23 全球购物
英国玛莎百货新西兰:Marks & Spencer New Zealand
2019/07/21 全球购物
装饰资料员岗位职责
2013/12/30 职场文书
学雷锋演讲稿
2014/03/04 职场文书
环保建议书500字
2014/05/14 职场文书
四风自我剖析材料
2014/09/30 职场文书
党的群众路线教育实践活动个人对照检查材料(乡镇)
2014/11/05 职场文书
物业工程部主管岗位职责
2015/04/16 职场文书
2015年国庆节新闻稿
2015/07/18 职场文书
中学图书馆工作总结
2015/08/11 职场文书
Win11 Build 22000.51版本文件资源管理器“命令栏”和上下文菜单有什么新变化?
2021/11/21 数码科技