Mybatis-plus在項目中的簡單應(yīng)用
本文是一篇隨筆,記錄項目中應(yīng)用的一些情景。
Mybatis-plus是Spring框架中OOM的一大利器,其簡單易用參考官網(wǎng)文檔即可很快上手。mp.baomidou.com/guide/
p6spy 執(zhí)行 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時才會注入,即手動設(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://chabaoo.cn/article/199726.htm
通用枚舉
通過@EnumValue標(biāo)記值,將數(shù)據(jù)庫中的枚舉值轉(zhuǎn)換沒枚舉類型,可以少做一步轉(zhuǎn)換。參考文章:http://chabaoo.cn/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);
到此這篇關(guān)于Mybatis-plus在項目中的簡單應(yīng)用的文章就介紹到這了,更多相關(guān)Mybatis-plus項目應(yīng)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MyBatis中關(guān)于resultType和resultMap的區(qū)別介紹
MyBatis中在查詢進行select映射的時候,返回類型可以用resultType,也可以用resultMap,那么MyBatis中關(guān)于resultType和resultMap的區(qū)別是什么呢?下面小編通過本文給大家解答下2016-09-09Spring Cache的基本使用與實現(xiàn)原理詳解
緩存是實際工作中非經(jīng)常常使用的一種提高性能的方法, 我們會在很多場景下來使用緩存。下面這篇文章主要給大家介紹了關(guān)于Spring Cache的基本使用與實現(xiàn)原理的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下2018-05-05MyBatis動態(tài)SQL如何實現(xiàn)前端指定返回字段
這篇文章主要介紹了MyBatis動態(tài)SQL如何實現(xiàn)前端指定返回字段,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01Eclipse 2020-06 漢化包安裝步驟詳解(附漢化包+安裝教程)
這篇文章主要介紹了Eclipse 2020-06 漢化包安裝步驟(附漢化包+安裝教程),本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-08-08