mybatisplus快速實(shí)現(xiàn)動(dòng)態(tài)數(shù)據(jù)源切換
在 MyBatis-Plus 中實(shí)現(xiàn)動(dòng)態(tài)數(shù)據(jù)源切換可以通過(guò)以下步驟進(jìn)行快速實(shí)現(xiàn):
1. 添加依賴:在項(xiàng)目的構(gòu)建文件(如 Maven 的 pom.xml)中添加 MyBatis-Plus 的依賴項(xiàng)。
com.baomidou
mybatis-plus-boot-starter
最新版本
2. 配置數(shù)據(jù)源:在項(xiàng)目的配置文件中配置多個(gè)數(shù)據(jù)源??梢允褂貌煌臄?shù)據(jù)庫(kù)連接信息來(lái)配置不同的數(shù)據(jù)源。
spring:
datasource:
dynamic:
primary: datasource1 # 指定默認(rèn)的主數(shù)據(jù)源
datasource:
datasource1:
url: jdbc:mysql://localhost:3306/db1
username: root
password: password1
datasource2:
url: jdbc:mysql://localhost:3306/db2
username: root
password: password2
3. 創(chuàng)建數(shù)據(jù)源切換器:自定義一個(gè)數(shù)據(jù)源切換器,實(shí)現(xiàn) `AbstractRoutingDataSource` 接口,并重寫 `determineCurrentLookupKey` 方法,根據(jù)業(yè)務(wù)邏輯返回要使用的數(shù)據(jù)源的名稱。
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;
public class DynamicDataSource extends AbstractRoutingDataSource {
@Override
protected Object determineCurrentLookupKey() {
// 根據(jù)業(yè)務(wù)邏輯返回?cái)?shù)據(jù)源的名稱
return DataSourceContextHolder.getDataSource();
}
}
4. 創(chuàng)建數(shù)據(jù)源上下文持有器:創(chuàng)建一個(gè)數(shù)據(jù)源上下文持有器類,用于存儲(chǔ)當(dāng)前線程使用的數(shù)據(jù)源名稱??梢允褂?`ThreadLocal` 來(lái)實(shí)現(xiàn)線程級(jí)別的數(shù)據(jù)源切換。
public class DataSourceContextHolder {
private static final ThreadLocal contextHolder = new ThreadLocal<>();
public static void setDataSource(String dataSourceName) {
contextHolder.set(dataSourceName);
}
public static String getDataSource() {
return contextHolder.get();
}
public static void clearDataSource() {
contextHolder.remove();
}
}
5. 配置數(shù)據(jù)源切換:在 Spring 的配置文件中配置數(shù)據(jù)源切換器和數(shù)據(jù)源上下文持有器。
@Configuration
public class DataSourceConfig {
@Bean
@ConfigurationProperties("spring.datasource")
public DataSource dataSource() {
return new DynamicDataSource();
}
@Bean
public SqlSessionFactory sqlSessionFactory(DataSource dataSource) throws Exception {
MybatisSqlSessionFactoryBean sessionFactory = new MybatisSqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
// 配置其他 MyBatis 相關(guān)設(shè)置
return sessionFactory.getObject();
}
@Bean
public PlatformTransactionManager transactionManager(DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
}
6. 使用注解切換數(shù)據(jù)源:在需要切換數(shù)據(jù)源的地方使用 `@DS` 注解指定要使用的數(shù)據(jù)源。
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
@Override
@DS("
datasource1") // 指定使用 datasource1 數(shù)據(jù)源
public List getUsers() {
return userMapper.selectList(null);
}
@Override
@DS("datasource2") // 指定使用 datasource2 數(shù)據(jù)源
public void addUser(User user) {
userMapper.insert(user);
}
}
data:image/s3,"s3://crabby-images/96fc1/96fc14f227b111498dd944948b81b724d7c53703" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/f85dc/f85dc0c8b0da276ec29f7537aedd79cead9397fd" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/ba316/ba31612335704278bebfe16f6b7476235e5ca3a1" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/bf8a1/bf8a1eea67a8f5393ca662bf7239b9b26741971a" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/b2b97/b2b976cb9db988ca05f8554510eabd48ada42575" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/cca68/cca6841f40e522883f758a6f3a9f2329f7f7a3ed" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/4eb74/4eb74807753b2942eb1ba94d79ecfae6f389571e" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/99d42/99d4201b6b47d22912e8dbbc752c01f5fcecbc41" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/af75f/af75f4fe45dd2f3cc617378f09952c13f05bb42c" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/86fdf/86fdf27dc4ab4bacbdca69450edf8f53e4efd760" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/a09e4/a09e4b804cbb6f4ae67d8cbb5bea9d8dd065f1ce" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/be183/be183e9895f7135b9be4abc1e1c5753d9f558db7" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/7676b/7676b4ecd68da582014ef1389a3d48b07b4834db" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/7f8ba/7f8ba245a5381eecbcff35373942bfaa76567029" alt=""
2023-12-09
data:image/s3,"s3://crabby-images/e4c0b/e4c0b42cd3fe0edf0f232669af486cd6495154ce" alt=""
2023-12-09
如何實(shí)現(xiàn)服務(wù)器負(fù)載均衡
linux有哪些優(yōu)勢(shì)和劣勢(shì)
linux需要驅(qū)動(dòng)嗎
android與linux的區(qū)別
如何搭建基于容器的深度學(xué)習(xí)環(huán)境
linux能干什么
linux是用什么語(yǔ)言寫的
linux云計(jì)算是什么
linux內(nèi)核是什么意思
數(shù)通是什么
什么是數(shù)據(jù)通信
OCI如何在線擴(kuò)展計(jì)算實(shí)例的引導(dǎo)卷大小
路由器qos是什么意思
什么是組播路由協(xié)議
什么叫組播協(xié)議
ospf路由協(xié)議使用什么算法
什么叫ospf鄰居
ospf鄰居交互用什么報(bào)文