Mybatis-plus如何应用在项目中
这篇文章主要为大家展示了“Mybatis-plus如何应用在项目中”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Mybatis-plus如何应用在项目中”这篇文章吧。
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)
@TableLogicprivate Integer deleted;
自动填充
妈妈再也不用管create_time,update_time了。默认注入字段值为null时才会注入,即手动设置值后不再注入。特别注意beanUtil.copy时的值问题。
可以从header、shiro、Security 中获取当前用户信息,更新createUser,updateUser
@Slf4j@Componentpublic 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处理。
@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() { MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor()); return interceptor;}@Versionprivate Integer version;
多数据源
有时会用,通过注解去切换数据源。参考文章:https://www.yisu.com/article/199726.htm
通用枚举
通过@EnumValue标记值,将数据库中的枚举值转换没枚举类型,可以少做一步转换。参考文章:https://www.yisu.com/article/194192.htm
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如何应用在项目中”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341