溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Mybatis-plus如何應(yīng)用在項(xiàng)目中

發(fā)布時間:2021-07-01 13:50:18 來源:億速云 閱讀:144 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要為大家展示了“Mybatis-plus如何應(yīng)用在項(xiàng)目中”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Mybatis-plus如何應(yīng)用在項(xiàng)目中”這篇文章吧。

Mybatis-plus是Spring框架中OOM的一大利器,其簡單易用參考官網(wǎng)文檔即可很快上手。mp.baomidou.com/guide/

p6spy 執(zhí)行 SQL 分析打印,只需加入依賴,加入配置文件即可有完美的sql打印。有性能損耗線上不能使用

分頁插件

只需注入插件即可,實(shí)在太方便了有沒有。

// 最新版
    @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  # 全局邏輯刪除的實(shí)體字段名(since 3.3.0,配置后可以忽略不配置步驟2)
      logic-delete-value: 1 # 邏輯已刪除值(默認(rèn)為 1)
      logic-not-delete-value: 0 # 邏輯未刪除值(默認(rèn)為 0)
@TableLogic
private Integer deleted;

自動填充

媽媽再也不用管create_time,update_time了。默認(rèn)注入字段值為null時才會注入,即手動設(shè)置值后不再注入。特別注意beanUtil.copy時的值問題。
可以從header、shiro、Security 中獲取當(dāng)前用戶信息,更新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)
    }
}

樂觀鎖

直接應(yīng)用比較少,針對特別情景,部分接口會做version處理。

@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
    MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
    interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
    return interceptor;
}

@Version
private Integer version;

多數(shù)據(jù)源

有時會用,通過注解去切換數(shù)據(jù)源。參考文章:http://kemok4.com/article/199726.htm

通用枚舉

通過@EnumValue標(biāo)記值,將數(shù)據(jù)庫中的枚舉值轉(zhuǎn)換沒枚舉類型,可以少做一步轉(zhuǎn)換。參考文章:http://kemok4.com/article/194192.htm

id生成及主鍵

分布式服務(wù)基本基于業(yè)務(wù)去切分?jǐn)?shù)據(jù)庫,一個微服務(wù)基本對應(yīng)一個庫,對大部分應(yīng)用不需要做分表的情景,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 當(dāng)有多個值是不會拋出異常。

LambdaQueryWrapper queryWrapper = Wrappers.<User>lambdaQuery()
.eq(User::getUserName,"123");
User user = userService.getOne(queryWrapper,false);

以上是“Mybatis-plus如何應(yīng)用在項(xiàng)目中”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI