精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

SpringBoot+Mybatis多數據源配置和切換

數據庫 其他數據庫
今天介紹一個SpringBoot+mybatis的多數據源的解決方案。

前言

在項目開發中,經常會涉及到一個應用程序調用多個數據的情況。今天介紹一個SpringBoot+mybatis的多數據源的解決方案。

數據庫準備

創建兩個數據庫,兩個數據庫都有Im_person表,兩個表中無數據。

代碼結構

說明:我這里只是為了體現效果,就省略了service步驟。各位大牛開發,不喜勿噴,理解萬歲,嘻嘻!!

  1. application.yml中配置兩個數據源,配置如下:
master:
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/db1?useUnicode=true&characterEncoding=utf-8&useSSL=false&allowMultiQueries=true&serverTimezone=GMT%2B8
username: root
password: 123456

slave:
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/db2?useUnicode=true&characterEncoding=utf-8&useSSL=false&allowMultiQueries=true&serverTimezone=GMT%2B8
username: root
password: 123456

2.SpringBoot多數據源配置類。

@Configuration
@MapperScan(basePackages = "com.zhangls.multipledatasource.dao.master", sqlSessionFactoryRef = "masterSqlSessionFactory")
public class MasterDataSourceConfig {
@Value("${master.datasource.driver-class-name}")
private String driverClassName;

@Value("${master.datasource.url}")
private String url;

@Value("${master.datasource.username}")
private String username;

@Value("${master.datasource.password}")
private String password;

@Bean(name = "masterDataSource")
@Primary
public DataSource dataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(this.driverClassName);
dataSource.setUrl(this.url);
dataSource.setUsername(this.username);
dataSource.setPassword(this.password);
return dataSource;
}

@Bean(name = "masterSqlSessionFactory")
@Primary
public SqlSessionFactory sqlSessionFactory(@Qualifier("masterDataSource") DataSource dataSource) throws Exception {
SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
bean.setDataSource(dataSource);
ResourcePatternResolver resourceResolver = new PathMatchingResourcePatternResolver();
List<String> mapperLocations = new ArrayList<>();
mapperLocations.add("classpath*:/mapper/master/*.xml");
List<Resource> resources = new ArrayList();
if (mapperLocations != null) {
for (String mapperLocation : mapperLocations) {
try {
Resource[] mappers = resourceResolver.getResources(mapperLocation);
resources.addAll(Arrays.asList(mappers));
} catch (IOException e) {
// ignore
}
}
}

bean.setMapperLocations(resources.toArray(new Resource[resources.size()]));
return bean.getObject();
}

@Bean(name = "masterTransactionManager")
@Primary
public DataSourceTransactionManager transactionManager(@Qualifier("masterDataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}

@Bean(name = "masterSqlSessionTemplate")
@Primary
public SqlSessionTemplate testSqlSessionTemplate(
@Qualifier("masterSqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {
return new SqlSessionTemplate(sqlSessionFactory);
}
}
@Configuration
@MapperScan(basePackages = "com.zhangls.multipledatasource.dao.slave", sqlSessionFactoryRef = "slaveSqlSessionFactory")
public class SlaveDataSourceConfig {
@Value("${slave.datasource.driver-class-name}")
private String driverClassName;

@Value("${slave.datasource.url}")
private String url;

@Value("${slave.datasource.username}")
private String username;

@Value("${slave.datasource.password}")
private String password;

@Bean(name = "slaveDataSource")
public DataSource dataSource() {
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(this.driverClassName);
dataSource.setUrl(this.url);
dataSource.setUsername(this.username);
dataSource.setPassword(this.password);
return dataSource;
}

@Bean(name = "slaveSqlSessionFactory")
public SqlSessionFactory sqlSessionFactory(@Qualifier("slaveDataSource") DataSource dataSource) throws Exception {
SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
bean.setDataSource(dataSource);
bean.setMapperLocations(
new PathMatchingResourcePatternResolver().getResources("classpath*:/mapper/slave/*.xml"));
return bean.getObject();
}

@Bean(name = "slaveTransactionManager")
public DataSourceTransactionManager transactionManager(@Qualifier("slaveDataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}

@Bean(name = "slaveSqlSessionTemplate")
public SqlSessionTemplate testSqlSessionTemplate(
@Qualifier("masterSqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {
return new SqlSessionTemplate(sqlSessionFactory);
}
}

說明:兩個數據的代碼基本相同,不同的是要配置好掃描包的路徑,以及mybatis的SQL文件的路徑。所以不同的連接DAO和mapper文件要放在不同的文件夾,方便配置管理。

實現效果

以上的配置已經實現了多數據源的配置,下面實現一個功能。通過一個接口同時向兩個庫的兩個表中導入不同的數據。

controller代碼如下:

@RestController
public class DataSourceController {
@Resource
private MasterPersonMapper masterPersonMapper;
@Resource
private SlavePersonMapper slavePersonMapper;

@GetMapping("/datasource")
public String datasource() {
ImPerson person1 = new ImPerson();
person1.setPersonId("1");
person1.setGender("男");
person1.setBirthday(new Date());
person1.setLocation("中國");
masterPersonMapper.insertSelective(person1);

ImPerson person2 = new ImPerson();
person2.setPersonId("2");
person2.setGender("女");
person2.setBirthday(new Date());
person2.setLocation("中國北京");
slavePersonMapper.insertSelective(person2);
return "導入成功";
}
}

執行:

結果:

可以看到兩個庫中的兩個表都導入了數據。

責任編輯:姜華 來源: 今日頭條
相關推薦

2024-10-30 10:22:17

2023-06-07 08:08:37

MybatisSpringBoot

2023-09-07 08:39:39

copy屬性數據源

2020-12-31 07:55:33

spring bootMybatis數據庫

2020-03-13 14:05:14

SpringBoot+數據源Java

2020-06-02 07:55:31

SpringBoot多數據源

2022-05-10 10:43:35

數據源動態切換Spring

2024-04-30 09:17:06

SpringBootMybatis動態數據源

2022-12-19 07:21:35

Hutool-db數據庫JDBC

2023-11-27 07:33:55

2010-12-27 09:59:11

ODBC數據源

2009-06-15 13:24:46

JBoss數據源

2020-11-24 09:56:12

數據源讀寫分離

2025-04-14 01:00:00

Calcite電商系統MySQL

2009-08-14 10:26:27

ibatis多數據源

2023-10-31 07:52:53

多數據源管理后端

2022-05-18 12:04:19

Mybatis數據源Spring

2024-11-20 09:12:56

2023-02-06 14:44:00

嚴選數據源DB

2025-01-09 11:21:25

點贊
收藏

51CTO技術棧公眾號

久久高清精品| 最新欧美电影| av在线播放一区二区三区| 欧美一级电影免费在线观看| 欧美亚洲色综久久精品国产| 欧美性www| 欧美日韩加勒比精品一区| 五月天色一区| 国产综合在线播放| 天堂va蜜桃一区二区三区| 久热精品视频在线观看一区| 久久人妻一区二区| 在线播放成人| 日本韩国欧美在线| 免费的一级黄色片| 福利小视频在线观看| 成人免费观看视频| 国产综合色香蕉精品| 日本少妇做爰全过程毛片| 日韩伦理一区| 亚洲毛片在线观看.| 超碰人人cao| 成人精品动漫| 欧美性极品xxxx娇小| 国产高清不卡无码视频| 三区四区电影在线观看| 久久久91精品国产一区二区精品| 97久草视频| 在线视频 中文字幕| 亚洲综合不卡| 午夜欧美大片免费观看| 美女毛片在线观看| 亚洲成人tv| 在线播放国产精品| 一二三不卡视频| 亚洲精品国产九九九| 欧美绝品在线观看成人午夜影视| 国产精品成人久久电影| 日本h片在线观看| 亚洲欧美日韩国产综合| 手机看片福利永久国产日韩| 久久电影中文字幕| 久久色视频免费观看| 九色综合日本| 凸凹人妻人人澡人人添| 成人a免费在线看| 成人免费观看网站| www.av黄色| 国产乱码精品一区二区三| 91久久久久久久一区二区| 中文字幕+乱码+中文| 日韩av午夜在线观看| 日产日韩在线亚洲欧美| 五月婷婷亚洲综合| 性伦欧美刺激片在线观看| 8090成年在线看片午夜| 黄色一级片免费在线观看| 亚洲尤物在线| 日本一区二区在线免费播放| 天堂网视频在线| 久久在线91| 国产精品美女视频网站| 一区精品在线观看| 激情欧美一区二区三区在线观看| 成人午夜黄色影院| 精品欧美在线观看| av激情综合网| 欧美aaaaa喷水| 北条麻妃在线| 亚洲欧美视频在线观看| 国产又粗又猛又爽又黄的网站| 欧美videossex| 欧美日韩一区二区免费在线观看 | 欧美午夜片在线免费观看 | 久久精品国产77777蜜臀| 国产日韩av在线播放| 国产视频手机在线| www.日韩大片| 亚洲国产精品一区在线观看不卡| av成人手机在线| 亚洲麻豆国产自偷在线| 日韩av在线播放不卡| 亚洲高清黄色| 制服丝袜av成人在线看| a级片在线观看视频| 国产精品欧美在线观看| 久久精品国产亚洲精品| 国产大片中文字幕| 日本aⅴ亚洲精品中文乱码| 91免费电影网站| 天堂av在线资源| 国产欧美1区2区3区| 成人手机在线播放| 亚洲福利影院| 欧美日韩亚州综合| www.17c.com喷水少妇| 加勒比久久综合| 欧美寡妇偷汉性猛交| 久久久精品毛片| 国产乱码精品一区二区三区忘忧草 | 国产成人av一区二区| 欧美日韩另类丝袜其他| 成人av福利| 91极品视觉盛宴| av不卡中文字幕| 欧美丝袜激情| 97国产精品免费视频| 97视频免费在线| 91网站最新网址| 久久久久久久久久久久久国产| 欧美久久天堂| 欧美一级欧美三级| 久久久久久国产免费a片| 亚洲国产激情| 亚洲一区美女视频在线观看免费| 欧美高清电影在线| 午夜久久久久久久久| 日韩不卡的av| 欧美大黑bbbbbbbbb在线| 欧洲中文字幕国产精品| 亚洲精品无amm毛片| 中文字幕亚洲成人| 成人精品小视频| 欧美丝袜美腿| 久久久久久尹人网香蕉| 国产免费一区二区三区免费视频| 日本一区二区三区在线不卡 | 日本特黄久久久高潮| 精品午夜一区二区| 欧美wwww| 精品国产乱子伦一区| 国产高清视频免费在线观看| 日韩精品亚洲专区| 欧美重口乱码一区二区| 三级中文字幕在线观看| 亚洲国产欧美精品| 国产一级片网址| 国产成人免费视频网站高清观看视频| 亚洲人成影视在线观看| 亚洲成av在线| 夜夜嗨av一区二区三区四区 | 欧美一区二区黄色| 一级片一级片一级片| 蜜臀91精品一区二区三区| 日产精品一线二线三线芒果 | 亚洲精品日韩av| 日本高清在线观看wwwww色| 欧洲激情一区二区| x88av在线| 喷白浆一区二区| 亚洲高清资源综合久久精品| 成人日韩精品| 最新日韩中文字幕| 91无套直看片红桃| 亚洲男人都懂的| 国产chinesehd精品露脸| 欧美大片一区| 国产在线一区二区三区欧美| 草草在线视频| 亚洲少妇中文在线| 亚洲精品一区二区二区| 国产精品美女久久久久久2018| 天天干天天玩天天操| 婷婷亚洲图片| 成人午夜影院在线观看| 欧美极品videos大乳护士| 亚洲天堂免费视频| 影音先锋黄色网址| 亚洲码国产岛国毛片在线| 中国免费黄色片| 丝瓜av网站精品一区二区| 亚洲乱码一区二区三区三上悠亚| 欧美高清免费| 欧美激情免费在线| 三级在线电影| 欧美日韩国产成人在线免费| 国产av无码专区亚洲av毛网站 | 欧美激情aaa| 免费欧美在线视频| 日韩一二区视频| 天海翼精品一区二区三区| 国产精品第1页| 日本伦理一区二区| 亚洲男人av在线| 国产毛片毛片毛片毛片毛片| 亚洲国产精品嫩草影院| 欧美激情 一区| 国产经典欧美精品| 成人免费毛片播放| 午夜精品久久久久99热蜜桃导演| 极品校花啪啪激情久久| www.26天天久久天堂| 精品国产依人香蕉在线精品| 欧美熟妇另类久久久久久不卡| 91成人免费在线视频| 久草视频中文在线| 欧美高清在线精品一区| 亚洲婷婷在线观看| 久久精品国产亚洲aⅴ| 97视频久久久| 日韩在线看片| 久久亚洲高清| 一区二区三区免费在线看| 日本精品免费观看| 免费在线中文字幕| 日韩视频―中文字幕| 色视频免费在线观看| 欧美一区二区精品在线| 国产美女www| 精品久久久视频| 国产1区2区3区4区| 亚洲国产激情av| 精品一区二区视频在线观看| 国产一区二区影院| 超碰在线人人爱| 先锋影音久久久| av免费看网址| 中文无码久久精品| 亚洲第一导航| 教室别恋欧美无删减版| 久久伊人一区二区| 国产精品chinese在线观看| 亚洲xxxxx性| 日韩av黄色| 国产精品视频一| 日韩新的三级电影| 欧美一区二区三区免费视| 8x8ⅹ拨牐拨牐拨牐在线观看| 久久深夜福利免费观看| 一级毛片视频在线| 国产亚洲人成a一在线v站| 少妇性bbb搡bbb爽爽爽欧美| 亚洲成人精品视频| 丁香六月天婷婷| 日韩欧美电影在线| 国产av无码专区亚洲av| 777精品伊人久久久久大香线蕉| 国产偷人爽久久久久久老妇app| 狠狠久久五月精品中文字幕| 日韩成人免费在线观看| 亚洲国产成人91porn| 久久久久久久久久久97| 一区二区三区欧美久久| 欧美a级片免费看| 亚洲视频每日更新| 91插插插插插插| 亚洲精品视频在线| 国产极品国产极品| 一区二区三区精品在线| 免费在线观看黄视频| 亚洲国产精品欧美一二99| 日本熟妇一区二区| 精品久久久免费| 国语对白做受69按摩| 欧美视频在线一区| 国产又粗又猛又爽又黄的视频一| 欧美午夜精品免费| 国产精品无码一区二区桃花视频| 555www色欧美视频| 国产夫妻自拍av| 亚洲成**性毛茸茸| 毛片网站在线| 色琪琪综合男人的天堂aⅴ视频| 黄色网址在线免费| 欧美疯狂性受xxxxx另类| 92久久精品| 日本视频久久久| 亚洲我射av| 国内精品二区| av一区二区在线播放| 欧美少妇一级片| 亚洲午夜久久久久久尤物| av网站在线观看不卡| 免费观看成人av| 少妇献身老头系列| 久久免费的精品国产v∧| 内射毛片内射国产夫妻| 亚洲精品午夜久久久| 久久久国产高清| 欧美男男青年gay1069videost | 青青在线视频免费观看| 亚洲在线观看| 奇米777在线视频| 不卡欧美aaaaa| 萌白酱视频在线| 亚洲国产精品久久久久秋霞影院| 久久久久99精品成人片我成大片| 欧美日韩成人一区| 五月天婷婷视频| 精品国产一区二区在线| sm在线播放| 91精品久久久久久久久| 全球av集中精品导航福利| 亚洲午夜精品久久| 亚洲激情黄色| 日本中文字幕观看| 91欧美激情一区二区三区成人| 欧美风情第一页| 色综合久久中文综合久久97| 精品女同一区二区三区| 一本大道亚洲视频| 美女网站视频在线| 国产噜噜噜噜噜久久久久久久久| 精品伊人久久久| 男同互操gay射视频在线看| 午夜在线a亚洲v天堂网2018| 久久精品一二三四| 国产视频一区不卡| 国产精品6666| 51精品国自产在线| 福利视频在线看| 亚洲2020天天堂在线观看| 欧美少妇激情| 日本一区二区三区视频免费看| 亚洲小说欧美另类社区| 日本国产一级片| 欧美国产精品一区| 中文字幕69页| 日韩av在线网| 92久久精品| 国产精品一区二区av| 性欧美欧美巨大69| 国产高清视频网站| 久久久久久久久99精品| 成年人免费看毛片| 精品欧美久久久| а√中文在线8| 成人福利视频在线观看| 成久久久网站| 亚洲不卡视频在线| 国产亚洲福利社区一区| 天天干天天色综合| 日韩经典中文字幕| 激情aⅴ欧美一区二区欲海潮| 99精彩视频| 一区二区在线| 亚洲一级片免费观看| 亚洲视频在线观看三级| 伊人久久国产精品| 综合网日日天干夜夜久久| 韩国成人在线| 日韩资源av在线| 青青草成人在线观看| 三区四区在线观看| 欧美影院精品一区| 在线观看免费黄色| 成人羞羞国产免费| 亚洲天天影视网| 亚洲AV成人精品| 激情懂色av一区av二区av| 天天摸天天干天天操| 91成人性视频| 国产麻豆一区二区三区精品视频| 50路60路老熟妇啪啪| 久久婷婷成人综合色| 免费无码国产精品| 日韩在线播放av| 大胆国模一区二区三区| 蜜臀av.com| 成人妖精视频yjsp地址| 特一级黄色大片| 国产视频精品xxxx| 国产精品亚洲d| 99精品视频网站| 成人夜色视频网站在线观看| 69视频免费在线观看| 一区二区三区四区在线观看视频 | 久久青草久久| xxxxx99| 日韩亚洲欧美在线| 1区2区3区在线| 日韩电影免费观看高清完整| 久久成人精品无人区| 欧美高清视频一区二区三区| 亚洲韩国欧洲国产日产av| 日本一区二区三区视频在线| 宅男一区二区三区| 成人av资源网站| 欧美日韩 一区二区三区| 久久亚洲国产成人| 老司机aⅴ在线精品导航| 亚洲乱码国产一区三区| 一区二区三区影院| 国产资源在线看| 亚洲va久久久噜噜噜久久天堂| 亚洲人成免费| 污污视频网站在线免费观看| 精品国产3级a| 成人在线观看免费播放| 日韩一区二区高清视频| 国产三级精品在线| 亚洲国产精品suv| 国产精品美女免费| 亚洲久久一区| 久久中文免费视频| 亚洲天堂av图片| 国产精东传媒成人av电影| www.久久91| 日韩欧美中文在线| 青青草原国产在线|