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 Swing实现自助取款机系统
Jun 11 Java/Android
图解排序算法之希尔排序Java实现
Jun 26 Java/Android
浅谈resultMap的用法及关联结果集映射
Jun 30 Java/Android
java解析XML详解
Jul 09 Java/Android
Java 在生活中的 10 大应用
Nov 02 Java/Android
Java 实战项目之家居购物商城系统详解流程
Nov 11 Java/Android
SpringBoot2零基础到精通之数据库专项精讲
Mar 22 Java/Android
Mybatis-plus配置分页插件返回统一结果集
Jun 21 Java/Android
SpringBoot使用ip2region获取地理位置信息的方法
Jun 21 Java/Android
SpringBoot项目部署到阿里云服务器的实现步骤
Jun 28 Java/Android
利用Java连接Hadoop进行编程
Jun 28 Java/Android
Java中的Kafka为什么性能这么快及4大核心详析
Sep 23 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
dedecms 制作模板中使用的全局标记图文教程
2007/03/11 PHP
PHP配置文件中最常用四个ini函数
2007/03/19 PHP
JavaScript 小型打飞机游戏实现原理说明
2010/10/28 Javascript
javascript 进阶篇2 CSS XML学习
2012/03/14 Javascript
JQuery入门——用one()方法绑定事件处理函数(仅触发一次)
2013/02/05 Javascript
JavaScript中获取样式的原生方法小结
2014/10/08 Javascript
javascript截取字符串小结
2015/04/28 Javascript
javascript数组去重的六种方法汇总
2015/08/16 Javascript
浅谈JS中的bind方法与函数柯里化
2016/08/10 Javascript
利用fecha进行JS日期处理
2016/11/21 Javascript
提高JavaScript执行效率的23个实用技巧
2017/03/01 Javascript
JS实现集合的交集、补集、差集、去重运算示例【ES5与ES6写法】
2019/02/18 Javascript
Python删除指定目录下过期文件的2个脚本分享
2014/04/10 Python
Python实现把xml或xsl转换为html格式
2015/04/08 Python
浅谈python可视化包Bokeh
2018/02/07 Python
python实现图片批量压缩程序
2018/07/23 Python
Windows下安装Scrapy
2018/10/17 Python
python事件驱动event实现详解
2018/11/21 Python
pandas分别写入excel的不同sheet方法
2018/12/11 Python
使用Python实现企业微信的自动打卡功能
2019/04/30 Python
python使用tomorrow实现多线程的例子
2019/07/20 Python
Python列表切片常用操作实例解析
2020/03/10 Python
Python爬虫之爬取淘女郎照片示例详解
2020/07/28 Python
Django rest framework分页接口实现原理解析
2020/08/21 Python
总结30个CSS3选择器
2017/04/13 HTML / CSS
HTML5移动端开发中的Viewport标签及相关CSS用法解析
2016/04/15 HTML / CSS
英国高档时尚男装购物网站:MR PORTER
2016/08/09 全球购物
英国女鞋购物网站:Moda in Pelle
2019/02/18 全球购物
建筑装饰学院室内设计专业个人自我评价
2013/12/07 职场文书
车间副主任岗位职责
2013/12/24 职场文书
老公给老婆的道歉信
2014/01/10 职场文书
晚宴邀请函范文
2014/01/15 职场文书
安全生产先进个人材料
2014/02/06 职场文书
个人廉洁自律承诺书
2014/03/27 职场文书
党的群众路线对照检查材料
2014/09/22 职场文书
学期个人自我总结
2015/02/13 职场文书