返回顶部
首页 > 资讯 > 后端开发 > Python >Mybatis-plus在项目中的简单应用
  • 373
分享到

Mybatis-plus在项目中的简单应用

2024-04-02 19:04:59 373人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录分页插件逻辑删除自动填充乐观锁多数据源通用枚举id生成及主键查询 LambdaQueryWrapper本文是一篇随笔,记录项目中应用的一些情景。 mybatis-plus是sp

本文是一篇随笔,记录项目中应用的一些情景。

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;

多数据源

有时会用,通过注解去切换数据源。参考文章:https://www.jb51.net/article/199726.htm

通用枚举

通过@EnumValue标记值,将数据库中的枚举值转换没枚举类型,可以少做一步转换。参考文章:Https://www.jb51.net/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在项目中的简单应用的文章就介绍到这了,更多相关Mybatis-plus项目应用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Mybatis-plus在项目中的简单应用

本文链接: https://lsjlt.com/news/129604.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作