设为首页收藏本站
网站公告 | 这是第一条公告
     

 找回密码
 立即注册
缓存时间22 现在时间22 缓存数据 关关难过关关过,夜夜难熬夜夜熬。万般皆苦,悲欢自渡,他人难悟。晚安!

关关难过关关过,夜夜难熬夜夜熬。万般皆苦,悲欢自渡,他人难悟。晚安!

查看: 202|回复: 1

springboot jdbcTemplate 多源配置及特殊场景使用说明

[复制链接]

  离线 

TA的专栏

  • 打卡等级:热心大叔
  • 打卡总天数:237
  • 打卡月天数:0
  • 打卡总奖励:4018
  • 最近打卡:2025-09-15 18:00:53
等级头衔

等級:晓枫资讯-上等兵

在线时间
5 小时

积分成就
威望
0
贡献
439
主题
407
精华
0
金钱
5353
积分
922
注册时间
2023-1-7
最后登录
2025-9-15

发表于 2025-8-28 03:57:15 | 显示全部楼层 |阅读模式

以mysql 说明:

对于多数据源中大致分为两种 一个mysql服务器,多个库,另外一种就是多个mysql服务器多个库表。

对于以上通用配置如下:以mysql8说明

  1. #第一个库
  2. spring.datasource.master.type=com.alibaba.druid.pool.DruidDataSource
  3. spring.datasource.master.jdbc-url=jdbc:mysql://localhost:3306/aa?&serverTimezone=Asia/Shanghai
  4. spring.datasource.master.username=**
  5. spring.datasource.master.password=**
  6. spring.datasource.master.driver-class-name=com.mysql.cj.jdbc.Driver
  7. #第二个库
  8. spring.datasource.slave.type=com.alibaba.druid.pool.DruidDataSource
  9. spring.datasource.slave.jdbcurl=jdbc:mysql://localhost:3306/bb?&serverTimezone=Asia/Shanghai
  10. #spring.datasource.slave.username=**
  11. #spring.datasource.slave.password=**
  12. #spring.datasource.slave.driver-class-name=com.mysql.cj.jdbc.Driver
复制代码

mysql8和mysql5版本上配置的驱动要注意  ,8对应 com.mysql.cj.jdbc.Driver   5对应com.mysql.jdbc.Driver

另外 我使用的是jdbc ,所以url就使用  jdbcurl.

以下 配置说明:

  1. @Configuration
  2. public class DataSourceConfiguration {
  3. @Bean
  4. @ConfigurationProperties(prefix = "spring.datasource.master")
  5. @Primary
  6. public DataSource masterDataSource() {
  7. return DataSourceBuilder.create().build();
  8. }
  9. @Bean
  10. @ConfigurationProperties(prefix = "spring.datasource.slave")
  11. public DataSource slaveDataSource() {
  12. return DataSourceBuilder.create().build();
  13. }
  14. @Bean
  15. @Primary
  16. public JdbcTemplate masterJdbcTemplate(@Qualifier("masterDataSource") DataSource primaryDataSource) {
  17. return new JdbcTemplate(primaryDataSource);
  18. }
  19. @Bean
  20. public JdbcTemplate slaveJdbcTemplate(@Qualifier("slaveDataSource") DataSource secondaryDataSource) {
  21. return new JdbcTemplate(secondaryDataSource);
  22. }
  23. }
复制代码

以下使用

@Resource(name = "masterJdbcTemplate") private JdbcTemplate masterJdbcTemplate; @Resource(name = "slaveJdbcTemplate") private JdbcTemplate slaveJdbcTemplate;

这以上 特别说明,针对bean的名字一定要备注上,不然会默认指向。

有一种特殊情景下使用说明: 

在数据同步的时候,需要进行执行事务。但是又是在同一个服务器下的两个库,这个时候我们实际执行的是mysql库的事务。这个时候我们使用一种不区分库而又要执行的事务。以下进行说明:

  1. spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
  2. spring.datasource.jdbc-url=jdbc:mysql://127.0.0.1:3306/?&serverTimezone=Asia/Shanghai
  3. spring.datasource.username=**
  4. spring.datasource.password=**
  5. spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
复制代码

使用这种,不指定库,只指定服务器。

配置:

  1. @Configuration
  2. public class DataSourceConfiguration {
  3. @Bean
  4. @ConfigurationProperties(prefix = "spring.datasource")
  5. public DataSource dataSource() {
  6. return DataSourceBuilder.create().build();
  7. }
  8. @Bean
  9. public JdbcTemplate jdbcTemplate(DataSource dataSource) {
  10. return new JdbcTemplate(dataSource);
  11. }
  12. }
复制代码

使用:

  1. @Autowired
  2. private JdbcTemplate jdbcTemplate;
复制代码

备注:这种模式使用,就需要在执行sql的方式注意: 格式:   .

例如: 需要执行a数据库的b表的sql:     a.b

补充一种使用方法 一个事务涉及到的多个sql,这些sql分别对应不同的database(事务针对服务器)

  1. @Autowired
  2. private TransactionTemplate transactionTemplate;
  3. transactionTemplate.execute(status -> {
  4. try {
  5. jdbcTemplate.execute("SET GTID_NEXT='" +gtid + "'");
  6. List<String> arrSql = JSON.parseArray(sqlArr, String.class);
  7. for (String sql : arrSql) {
  8. jdbcTemplate.execute(sql);
  9. }
  10. return null;
  11. } catch (Exception e) {
  12. status.setRollbackOnly();
  13. e.printStackTrace();
  14. return null;
  15. }
  16. });
复制代码

到此这篇关于springboot jdbcTemplate 多源配置以及特殊场景使用的文章就介绍到这了,更多相关springboot jdbcTemplate 多源配置内容请搜索晓枫资讯以前的文章或继续浏览下面的相关文章希望大家以后多多支持晓枫资讯!


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
晓枫资讯-科技资讯社区-免责声明
免责声明:以上内容为本网站转自其它媒体,相关信息仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同其观点或证实其内容的真实性。
      1、注册用户在本社区发表、转载的任何作品仅代表其个人观点,不代表本社区认同其观点。
      2、管理员及版主有权在不事先通知或不经作者准许的情况下删除其在本社区所发表的文章。
      3、本社区的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,举报反馈:点击这里给我发消息进行删除处理。
      4、本社区一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
      5、以上声明内容的最终解释权归《晓枫资讯-科技资讯社区》所有。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
20
积分
20
注册时间
2022-12-26
最后登录
2022-12-26

发表于 2025-10-31 23:56:17 | 显示全部楼层
感谢楼主分享。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~
严禁发布广告,淫秽、色情、赌博、暴力、凶杀、恐怖、间谍及其他违反国家法律法规的内容。!晓枫资讯-社区
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1楼
2楼

手机版|晓枫资讯--科技资讯社区 本站已运行

CopyRight © 2022-2025 晓枫资讯--科技资讯社区 ( BBS.yzwlo.com ) . All Rights Reserved .

晓枫资讯--科技资讯社区

本站内容由用户自主分享和转载自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

如有侵权、违反国家法律政策行为,请联系我们,我们会第一时间及时清除和处理! 举报反馈邮箱:点击这里给我发消息

Powered by Discuz! X3.5

快速回复 返回顶部 返回列表