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的MathML转图片的方法(示例代码)
Jun 23 Java/Android
Java数组与堆栈相关知识总结
Jun 29 Java/Android
Java实现多文件上传功能
Jun 30 Java/Android
springboot临时文件存储目录配置方式
Jul 01 Java/Android
看完这篇文章获得一些java if优化技巧
Jul 15 Java/Android
Jpa Specification如何实现and和or同时使用查询
Nov 23 Java/Android
解析探秘fescar分布式事务实现原理
Feb 28 Java/Android
SpringBoot中使用Redis作为全局锁示例过程
Mar 24 Java/Android
Android超详细讲解组件ScrollView的使用
Mar 31 Java/Android
Java 垃圾回收超详细讲解记忆集和卡表
Apr 08 Java/Android
SpringCloud Function SpEL注入漏洞分析及环境搭建
Apr 08 Java/Android
SpringBoot项目多数据源及mybatis 驼峰失效的问题解决方法
Jul 07 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
1.PHP简介
2006/10/09 PHP
微信公众号开发之微信公共平台消息回复类实例
2014/11/14 PHP
Ubuntu中搭建Nginx、PHP环境最简单的方法
2015/03/05 PHP
PHP操作MySQL的mysql_fetch_* 函数的常见用法教程
2015/12/25 PHP
PHP session 会话处理函数
2016/06/06 PHP
PHP简单实现模拟登陆功能示例
2017/09/15 PHP
PHP面向对象五大原则之里氏替换原则(LSP)详解
2018/04/08 PHP
Laravel框架自定义验证过程实例分析
2019/02/01 PHP
Apache站点配置SSL强制跳转443
2021/03/09 Servers
dropdownlist之间的互相联动实现(显示与隐藏)
2009/11/24 Javascript
jQuery ul标签下拉菜单演示代码
2010/12/11 Javascript
使用JavaScript判断图片是否加载完成的三种实现方式
2014/05/04 Javascript
javascript连续赋值问题
2015/07/08 Javascript
PHP结合jQuery实现的评论顶、踩功能
2015/07/22 Javascript
JavaScript学习笔记之数组求和方法
2016/03/23 Javascript
Javascript必知必会(四)js类型转换
2016/06/08 Javascript
bootstrap 点击空白处popover弹出框隐藏实例
2018/01/24 Javascript
解决Vue+Element ui开发中碰到的IE问题
2018/09/03 Javascript
vue获取data数据改变前后的值方法
2019/11/07 Javascript
详解webpack的clean-webpack-plugin插件报错
2020/10/16 Javascript
Python实现的简单算术游戏实例
2015/05/26 Python
Python pyinotify日志监控系统处理日志的方法
2018/03/08 Python
Python实现的根据文件名查找数据文件功能示例
2018/05/02 Python
numpy 进行数组拼接,分别在行和列上合并的实例
2018/05/08 Python
python实现监控某个服务 服务崩溃即发送邮件报告
2018/06/21 Python
使用Python代码实现Linux中的ls遍历目录命令的实例代码
2019/09/07 Python
python剪切视频与合并视频的实现
2020/03/03 Python
Python使用grequests并发发送请求的示例
2020/11/05 Python
深入解析HTML5的IndexedDB索引数据库
2015/09/14 HTML / CSS
无工作经验者个人求职信范文
2013/12/22 职场文书
先进党支部事迹材料
2014/01/13 职场文书
蟋蟀的住宅教学反思
2014/04/26 职场文书
信息与工商管理职业规划范文:为梦想而搏击
2014/09/11 职场文书
喝酒驾驶检讨书
2014/10/01 职场文书
2014年煤矿工作总结
2014/11/24 职场文书
2016年五一促销广告语
2016/01/28 职场文书