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!
推薦閱讀:
- Mybatis plus通用字段自動填充的示例
- MP(MyBatis-Plus)實現樂觀鎖更新功能的示例代碼
- MyBatis-Plus樂觀鎖插件的用法小結
- Mybatis-Plus自動填充更新操作相關字段的實現
- Mybatis-Plus實現公共字段自動賦值的方法