Mybatis-plus在項(xiàng)目中的簡(jiǎn)單應(yīng)用
本文是一篇隨筆,記錄項(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中stack的使用方法,堆棧是一種"后進(jìn)先出"(LIFO) 的數(shù)據(jù)結(jié)構(gòu), 只能在一端進(jìn)行插入(稱(chēng)為"壓棧") 或刪除 (稱(chēng)為"出棧")數(shù)據(jù)的操作,下面看示例吧2013-12-12java發(fā)送email一般步驟(實(shí)例講解)
下面小編就為大家?guī)?lái)一篇java發(fā)送email一般步驟(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09MyBatis中關(guān)于resultType和resultMap的區(qū)別介紹
MyBatis中在查詢進(jìn)行select映射的時(shí)候,返回類(lèi)型可以用resultType,也可以用resultMap,那么MyBatis中關(guān)于resultType和resultMap的區(qū)別是什么呢?下面小編通過(guò)本文給大家解答下2016-09-09Spring 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-05MyBatis動(dòng)態(tài)SQL如何實(shí)現(xiàn)前端指定返回字段
這篇文章主要介紹了MyBatis動(dòng)態(tài)SQL如何實(shí)現(xiàn)前端指定返回字段,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01Eclipse 2020-06 漢化包安裝步驟詳解(附漢化包+安裝教程)
這篇文章主要介紹了Eclipse 2020-06 漢化包安裝步驟(附漢化包+安裝教程),本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08