網站首頁 編程語言 正文
公司有個項目需要同時連接oracle和mysql數據庫,配置多源數據庫后發現分頁查詢會出現異常。
原因是,項目原來的分頁攔截器的配置如下,只能支持oracle的分頁
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.ORACLE));
return interceptor;
}
后來考慮能否通過某種方式動態實現,經過查看PaginationInnerInterceptor的源碼發現,實際上當沒有配置分頁攔截器的數據庫類型時會自動獲取。
...
IDialect dialect = findIDialect(executor);
...
protected IDialect findIDialect(Executor executor) {
if (dialect != null) {
return dialect;
}
if (dbType != null) {
dialect = DialectFactory.getDialect(dbType);
return dialect;
}
return DialectFactory.getDialect(JdbcUtils.getDbType(executor));
}
所以根本就不用指定數據庫類型,按照如下方式配置即可支持不同類型多源數據庫的分頁查詢
public class MybatisPlusConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new PaginationInnerInterceptor());
return interceptor;
}
原文鏈接:https://blog.csdn.net/Jay_fanwj/article/details/129404581
- 上一篇:沒有了
- 下一篇:沒有了
相關推薦
- 2023-02-04 GO語言并發之好用的sync包詳解_Golang
- 2023-01-08 Go設計模式原型模式考查點及使用詳解_Golang
- 2023-12-06 Request method ‘PUT‘ not supported
- 2022-06-24 淺談Golang的new與make區別是什么_Golang
- 2022-09-13 Oracle使用fy_recover_data恢復truncate刪除的數據_oracle
- 2022-12-06 python中讀取txt文件時split()函數的妙用_python
- 2022-09-29 Kotlin協程launch原理詳解_Android
- 2023-11-18 數據處理使用Python提取String、字符串中的數字
- 欄目分類
-
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支