欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis-plus在項(xiàng)目中的簡(jiǎn)單應(yīng)用

 更新時(shí)間:2021年07月01日 11:36:04   作者:Rubble  
Mybatis-plus是Spring框架中OOM的一大利器,其簡(jiǎn)單易用參考官網(wǎng)文檔即可很快上手,本文主要介紹了邏輯刪除,自動(dòng)填充,分頁(yè)插件等的簡(jiǎn)單使用,感興趣的可以了解一下

本文是一篇隨筆,記錄項(xiàng)目中應(yīng)用的一些情景。

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

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

分頁(yè)插件

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

// 最新版
    @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;

自動(dòng)填充

媽媽再也不用管create_time,update_time了。默認(rèn)注入字段值為null時(shí)才會(huì)注入,即手動(dòng)設(shè)置值后不再注入。特別注意beanUtil.copy時(shí)的值問(wèn)題。
可以從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)
    }
}

樂(lè)觀鎖

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

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

@Version
private Integer version;

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

有時(shí)會(huì)用,通過(guò)注解去切換數(shù)據(jù)源。參考文章:http://www.dbjr.com.cn/article/199726.htm

通用枚舉

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

id生成及主鍵

分布式服務(wù)基本基于業(yè)務(wù)去切分?jǐn)?shù)據(jù)庫(kù),一個(gè)微服務(wù)基本對(duì)應(yīng)一個(gè)庫(kù),對(duì)大部分應(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();

邏輯唯一時(shí)查詢一個(gè)值,false 當(dāng)有多個(gè)值是不會(huì)拋出異常。

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

到此這篇關(guān)于Mybatis-plus在項(xiàng)目中的簡(jiǎn)單應(yīng)用的文章就介紹到這了,更多相關(guān)Mybatis-plus項(xiàng)目應(yīng)用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java堆棧類(lèi)使用實(shí)例(java中stack的使用方法)

    java堆棧類(lèi)使用實(shí)例(java中stack的使用方法)

    java中stack的使用方法,堆棧是一種"后進(jìn)先出"(LIFO) 的數(shù)據(jù)結(jié)構(gòu), 只能在一端進(jìn)行插入(稱(chēng)為"壓棧") 或刪除 (稱(chēng)為"出棧")數(shù)據(jù)的操作,下面看示例吧
    2013-12-12
  • java發(fā)送email一般步驟(實(shí)例講解)

    java發(fā)送email一般步驟(實(shí)例講解)

    下面小編就為大家?guī)?lái)一篇java發(fā)送email一般步驟(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • MyBatis中關(guān)于resultType和resultMap的區(qū)別介紹

    MyBatis中關(guān)于resultType和resultMap的區(qū)別介紹

    MyBatis中在查詢進(jìn)行select映射的時(shí)候,返回類(lèi)型可以用resultType,也可以用resultMap,那么MyBatis中關(guān)于resultType和resultMap的區(qū)別是什么呢?下面小編通過(guò)本文給大家解答下
    2016-09-09
  • Spring Cache的基本使用與實(shí)現(xiàn)原理詳解

    Spring Cache的基本使用與實(shí)現(xiàn)原理詳解

    緩存是實(shí)際工作中非經(jīng)常常使用的一種提高性能的方法, 我們會(huì)在很多場(chǎng)景下來(lái)使用緩存。下面這篇文章主要給大家介紹了關(guān)于Spring Cache的基本使用與實(shí)現(xiàn)原理的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-05-05
  • Java責(zé)任鏈設(shè)計(jì)模式

    Java責(zé)任鏈設(shè)計(jì)模式

    這篇文章主要介紹了Java責(zé)任鏈設(shè)計(jì)模式的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • MyBatis動(dòng)態(tài)SQL如何實(shí)現(xiàn)前端指定返回字段

    MyBatis動(dòng)態(tài)SQL如何實(shí)現(xiàn)前端指定返回字段

    這篇文章主要介紹了MyBatis動(dòng)態(tài)SQL如何實(shí)現(xiàn)前端指定返回字段,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • JPA原生SQL(自定義SQL)分頁(yè)查詢邏輯詳解

    JPA原生SQL(自定義SQL)分頁(yè)查詢邏輯詳解

    這篇文章主要介紹了JPA原生SQL(自定義SQL)分頁(yè)查詢邏輯詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java中Cglib代理和JDK代理的區(qū)別詳解

    Java中Cglib代理和JDK代理的區(qū)別詳解

    這篇文章主要介紹了Java中Cglib代理和JDK代理的區(qū)別詳解,Cglib代理功能更強(qiáng),無(wú)論目標(biāo)類(lèi)是否實(shí)現(xiàn)了接口都可以代理,他是基于繼承的方式來(lái)代理目標(biāo)類(lèi),如果目標(biāo)類(lèi)也實(shí)現(xiàn)了接口,代理類(lèi)也會(huì)實(shí)現(xiàn)一次,需要的朋友可以參考下
    2023-09-09
  • Eclipse 2020-06 漢化包安裝步驟詳解(附漢化包+安裝教程)

    Eclipse 2020-06 漢化包安裝步驟詳解(附漢化包+安裝教程)

    這篇文章主要介紹了Eclipse 2020-06 漢化包安裝步驟(附漢化包+安裝教程),本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • java單鏈表逆序用法代碼示例

    java單鏈表逆序用法代碼示例

    這篇文章主要介紹了java單鏈表逆序用法代碼示例,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01

最新評(píng)論