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)
@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項目應用內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: