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 相关文章推荐
springboot @ConfigurationProperties和@PropertySource的区别
Jun 11 Java/Android
SpringCloud Alibaba项目实战之nacos-server服务搭建过程
Jun 21 Java/Android
详解Java实现设计模式之责任链模式
Jun 23 Java/Android
Java 泛型详解(超详细的java泛型方法解析)
Jul 02 Java/Android
JavaGUI模仿QQ聊天功能完整版
Jul 04 Java/Android
Logback 使用TurboFilter实现日志级别等内容的动态修改操作
Aug 30 Java/Android
解析探秘fescar分布式事务实现原理
Feb 28 Java/Android
Spring Bean是如何初始化的详解
Mar 22 Java/Android
详解Flutter和Dart取消Future的三种方法
Apr 07 Java/Android
Android Studio实现带三角函数对数运算功能的高级计算器
May 20 Java/Android
HttpClient实现表单提交上传文件
Aug 14 Java/Android
Android实现获取短信验证码并自动填充
May 21 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
Terran剧情介绍
2020/03/14 星际争霸
php自动注册登录验证机制实现代码
2011/12/20 PHP
PHP合并数组+号和array_merge的区别
2015/06/25 PHP
php+Memcached实现简单留言板功能示例
2017/02/15 PHP
php设计模式之策略模式应用案例详解
2019/06/17 PHP
ThinkPHP5+UEditor图片上传到阿里云对象存储OSS功能示例
2019/08/05 PHP
关于用Jquery的height()、width()计算动态插入的IMG标签的宽高的问题
2010/12/08 Javascript
Node.js(安装,启动,测试)
2014/06/09 Javascript
jQuery 过滤方法filter()选择具有特殊属性的元素
2014/06/15 Javascript
javascript原始值和对象引用实例分析
2015/04/25 Javascript
跟我学习javascript的基本类型和引用类型
2015/11/16 Javascript
基于JavaScript操作DOM常用的API小结
2015/12/01 Javascript
EasyUI Pagination 分页的两种做法小结
2016/07/09 Javascript
AngularJS中isolate scope的用法分析
2016/11/22 Javascript
浅谈Angular2 ng-content 指令在组件中嵌入内容
2017/08/18 Javascript
小程序实现选择题选择效果
2018/11/04 Javascript
JavaScript 防盗链的原理以及破解方法
2020/12/29 Javascript
python一键升级所有pip package的方法
2017/01/16 Python
python如何派生内置不可变类型并修改实例化行为
2018/03/21 Python
TensorFlow实现模型评估
2018/09/07 Python
pandas 数据结构之Series的使用方法
2019/06/21 Python
Python 字节流,字符串,十六进制相互转换实例(binascii,bytes)
2020/05/11 Python
Pandas的Apply函数具体使用
2020/07/21 Python
King Apparel官网:英国街头服饰品牌
2019/09/05 全球购物
工程业务员工作职责
2013/12/07 职场文书
优秀团队获奖感言
2014/02/19 职场文书
年会搞笑主持词
2014/03/27 职场文书
鉴定评语大全
2014/05/05 职场文书
2015年元旦活动总结
2014/05/09 职场文书
化工专业自荐书
2014/06/16 职场文书
关于运动会的广播稿(10篇)
2014/09/12 职场文书
2014年党风廉政工作总结
2014/12/03 职场文书
导游词之新疆-喀纳斯
2019/10/10 职场文书
将图片保存到mysql数据库并展示在前端页面的实现代码
2021/05/02 MySQL
使用javascript解析二维码的三种方式
2021/11/11 Javascript
Sql Server之数据类型详解
2022/02/28 SQL Server