百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

官方建议!Spring Boot多数据源正确实现方式

liuian 2025-07-27 21:58 31 浏览

环境:SpringBoot3.4.2



1. 简介

如果需要配置多个数据源,你就必须将其中一个数据源实例标记为 @Primary,因为接下来的各种自动配置都希望能通过类型获得其中一个。

如果创建了自己的数据源,自动配置的默认数据源就不会生效。接下来通过一个完整示例展示如何在项目中配置多个数据源。

2. 实战案例

Spring Boot 提供了一个名为 DataSourceBuilder 的实用构建器类,可用于创建一个标准数据源(如果它在类路径上)。生成器可根据类路径上的可用数据源检测要使用的数据源。它还能根据 JDBC URL 自动检测驱动程序。

2.1 数据源配置信息

app:
  datasource:
    first:
      url: "jdbc:mysql://localhost:3306/ds1"
      username: "root"
      password: "123123"
      configuration:
        minimumIdle: 20
        maximumPoolSize: 20
    second:
      url: "jdbc:mysql://localhost:3306/ds2"
      username: "root"
      password: "123123"
      configuration:
        minimumIdle: 10
        maximumPoolSize: 10

以上配置了2个数据源first,second。configuration属性节点是针对连接池进行配置。如果你有更多的数据源配置,按照上面方式添加即可。接下来是数据源bean的配置。

2.2 配置多数据源Bean

@Configuration(proxyBeanMethods = false)
public class MultiDataSourcesConfiguration {
  @Bean
  @Primary
  @ConfigurationProperties("app.datasource.first")
  DataSourceProperties firstDataSourceProperties() {
    return new DataSourceProperties();
  }


  @Bean
  @Primary
  // 这里指定连接池的其它信息进行绑定
  @ConfigurationProperties("app.datasource.first.configuration")
  HikariDataSource firstDataSource(DataSourceProperties firstDataSourceProperties) {
    return firstDataSourceProperties.initializeDataSourceBuilder().type(HikariDataSource.class).build();
  }


  @Bean
  @ConfigurationProperties("app.datasource.second")
  DataSourceProperties secondDataSourceProperties() {
    return new DataSourceProperties();
  }


  @Bean
  @ConfigurationProperties("app.datasource.second.configuration")
  HikariDataSource secondDataSource(
      @Qualifier("secondDataSourceProperties") DataSourceProperties secondDataSourceProperties) {
    return secondDataSourceProperties.initializeDataSourceBuilder().type(HikariDataSource.class).build();
  }
}

上面调用的DataSourceProperties#
initializeDataSourceBuilder
方法,其本质调用的是DataSourceBuilder类进行数据源的构建。

这里的@Primary不是必须的,以上的配置逻辑与 Spring Boot 在自动配置中使用的逻辑相同。

在通常情况下,当我们使用JPA或MyBatis等持久层框架时,针对单个数据源的配置通常比较简单,只需要配置好数据源和框架的相关设置即可。然而,当涉及到多数据源的场景时,配置会相对复杂一些,因为我们需要为每个数据源单独配置JPA或MyBatis。接下来将针对JPA进行多数据源情况的配置。

2.3 JPA配置

由于配置的比较多,这里就针对一个数据源进行配置,其它数据源除了定义名称不一样外其它都一样。

配置文件

app:
  jpa:
    first:
      generateDdl: false
      openInView: true
      show-sql: true
    second:
      generateDdl: false
      openInView: true
      show-sql: true

配置类,需要配置jpa的核心类EntityManagerFactory及事务管理器。

@Configuration(proxyBeanMethods = false)
@EnableJpaRepositories(basePackages = {"com.pack.ds1"}, 
  entityManagerFactoryRef = "firstEntityManagerFactory", transactionManagerRef = "firstJPATransactionManager")
public class FirstEntityManagerFactoryConfiguration {


  @Bean
  @ConfigurationProperties("app.jpa.first")
  JpaProperties firstJpaProperties() {
    return new JpaProperties();
  }
  @Bean
  LocalContainerEntityManagerFactoryBean firstEntityManagerFactory(DataSource firstDataSource,
      JpaProperties firstJpaProperties) {
    Map<String, Object> properties = new HashMap<>();
    // 自动生成/更新表结构
    properties.put("hibernate.hbm2ddl.auto", "update");
    EntityManagerFactoryBuilder builder = createEntityManagerFactoryBuilder(firstJpaProperties) ;
    return builder.dataSource(firstDataSource).packages("com.pack.ds1").properties(properties).persistenceUnit("firstDs").build() ;
  }
  private EntityManagerFactoryBuilder createEntityManagerFactoryBuilder(JpaProperties jpaProperties) {
    JpaVendorAdapter jpaVendorAdapter = createJpaVendorAdapter(jpaProperties);
    return new EntityManagerFactoryBuilder(jpaVendorAdapter, jpaProperties.getProperties(), null);
  }
  private JpaVendorAdapter createJpaVendorAdapter(JpaProperties jpaProperties) {
    return new HibernateJpaVendorAdapter() ;
  }
  // 事务管理器必须配置(针对的那个数据源)
  @Bean
  PlatformTransactionManager firstJPATransactionManager(EntityManagerFactory firstEntityManagerFactory) {
    JpaTransactionManager tm = new JpaTransactionManager(firstEntityManagerFactory) ;
    return tm;
  }
}

其它数据源与上面配置是一样的。到此所有的配置就完成了,接下来你就可以像操作单数据源一样进行编码了,注意:针对不同数据源所建立的Repository放到对应的包中即可。

测试

// com.pack.ds1包
@Entity
@Table(name = "t_student")
public class Student {


  @Id
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  private Long id ;
  private String name ;
}
public interface StudentRepository extends JpaRepository<Student, Long>{}
// com.pack.ds2包
@Entity
@Table(name = "t_teacher")
public class Teacher {


  @Id
  @GeneratedValue(strategy = GenerationType.IDENTITY)
  private Long id ;
  private String name ;
}
public interface TeacherRepository extends JpaRepository<Teacher, Long> {}

单元测试

@Resource
private StudentRepository studentRepository ;
@Resource
private TeacherRepository teacherRepository ;


@Test
public void test() {
  Student student = new Student() ;
  student.setName("张三") ;
  Teacher teacher = new Teacher() ;
  teacher.setName("王老师") ;
  this.studentRepository.save(student) ;
  this.teacherRepository.save(teacher) ;
}

这样就分别保存到了不同的数据库中。

相关推荐

pdf版本怎么弄(怎么把word转为pdf)

回答如下:要将PDF文件恢复到以前的版本,您需要执行以下步骤:1.找到保存PDF文件的文件夹或位置。2.在该位置中找到以前的版本,这可能是备份文件、自动保存文件或之前保存的版本。3.如果您没有备...

怎么几个电脑共用一台打印机
  • 怎么几个电脑共用一台打印机
  • 怎么几个电脑共用一台打印机
  • 怎么几个电脑共用一台打印机
  • 怎么几个电脑共用一台打印机
笔记本电脑本地连接连不上(笔记本本地连接不上什么原因)
  • 笔记本电脑本地连接连不上(笔记本本地连接不上什么原因)
  • 笔记本电脑本地连接连不上(笔记本本地连接不上什么原因)
  • 笔记本电脑本地连接连不上(笔记本本地连接不上什么原因)
  • 笔记本电脑本地连接连不上(笔记本本地连接不上什么原因)
万能bt搜索引擎网站(bt万能搜索破解版)

最好用最全面的的磁力搜索引擎是磁力熊,因为它是一个内容丰富、还是功能最为强大的一个磁力搜索网站,通过它不仅仅可以搜索磁力熊磁力熊,是一个内容丰富、功能最为强大的一个磁力搜索网站,通过它不仅仅可以搜索...

苹果id注册官网登录(appleid官网注册账号)

浏览器访问申请AppleID官网注册  1、在浏览器地址栏上面输入:“https://appleid.apple.com/cn”,进入申请AppleID官网界面,点击下面的“创建AppleID...

苹果笔记本怎么下载windows系统

方法一:使用BootCamp方法二:使用虚拟机方法三:使用Wine简介BootCamp是苹果电脑自带的一个软件,可以帮助用户在Mac上安装Windows操作系统。虚拟机则是运行在Mac上的一个软件...

华硕电脑激活码(华硕电脑windows激活码在哪里)

你所说的应该是系统激活密钥吧华硕OEM密钥就行!HomePremium(家庭高级版):27GBM-Y4QQC-JKHXW-D9W83-FJQKDUltimate(旗舰版):6K2KY-BF...

wifi如何防止别人蹭网(wifi如何防止别人蹭网呢)

防止WIFI被蹭网的方法1、家庭的wifi信号,一般是通过设置无线路由器发射出来。在设置无线路由器时,一定要注意设置无线密码的安全强度。最好含有大小写字母加数字的组合,不要设置连续数字,比如“1234...

无线ap安装示意图(无线ap如何安装方法)

商用无线ap安装完成后连接ap应用添加wifi网络信号将无线网卡插入电脑USBWindows7/8系统下,网卡安装成功后直接进行软件安装...2.继续安装类型,推荐保持默认选择,点击“下一步”继续安装...

miui官网开发版下载(小米miui开发版下载)

你好,miui12开发版下载方式如下1打开浏览器,登录小米Rom官网,2进去之后搜索自己的手机型号,3点击进入就可以看到所有发布过的miui版本4点击想要的12版本下载即可。现在的MIUI开发版需要申...

惠普台式机进入bios设置u盘启动
惠普台式机进入bios设置u盘启动

设置u盘启动的步骤如下:1、首先,将u盘插入hp台式机的USB接口处。2、开机快速断续的按F10键进入BIOS设置界面。3、将光标移到【BootDevicePriority】选项按回车键进入。4、选择【HDDGroupBootPr...

2026-01-15 00:37 liuian

云手机免费版无限挂机怎么用

1、登陆后,如果需要挂网页游戏,点击服务器的左下角,找到IE浏览器,然后打开网页游戏,登陆你的账号就行了,不要关闭IE浏览器,你的网页游戏就会24小时挂在云服务器上面。2、如果想要挂机,打开IE浏览器...

上海最近3天疫情情况(上海近几天的新冠疫情情况)

根据国家卫健委的每天疫情通报及上海市的疫情通报,上海没有一个区属中高风险地区,所以从上海任何一个区返乡都不需要隔离14天。上海这么大的城市,每天人来人往的Ill流不息,能继续做到区级地区没有中高级风险...

windows media player怎么下载

方法如下:在安装WMP11时只是把C:\DocumentsandSettings\AllUsers\ApplicationData\WindowsGenuineAdvantage\data...

during(during用法)

during用来表示一段时间,其意义大致相当于in的用法。一般来说,凡是能用in的地方,也可以用during.例如:Hecametoseemeduringmyabsence.Don’t...