当前位置:   article > 正文

springboot+hibernate(jpa)配置多数据源_spring boot hibernate配置多数据源

spring boot hibernate配置多数据源

 个人在配置完spring boot多数据源后报错!仔细看了报错的信息提示创建从数据源bean失败,最后还是因为自己不仔细造成的,从数据库少创建一张表。废话不说直接贴代码!
pom.xml 文件就不上了,正常的依赖包。
application.properties 配置信息:

  1. #主数据源
  2. spring.datasource.primary.url=jdbc:mysql://localhost:3306/test1?useUnicode=true&characterEncoding=utf-8&serverTimezone=UTC&useSSL=true
  3. spring.datasource.primary.username=root
  4. spring.datasource.primary.password=root
  5. spring.datasource.primary.driver-class-name=com.mysql.jdbc.Driver
  6. spring.datasource.max-active=10
  7. spring.datasource.primary.max-idle=5
  8. spring.datasource.primary.min-idle=0
  9. #从数据源
  10. spring.datasource.secondary.url=jdbc:mysql://localhost:3306/test2?characterEncoding=utf-8&serverTimezone=UTC&useSSL=true
  11. spring.datasource.secondary.username=root
  12. spring.datasource.secondary.password=root
  13. spring.datasource.secondary.driver-class-name=com.mysql.jdbc.Driver
  14. spring.datasource.secondary.max-active=10
  15. spring.datasource.secondary.max-idle=5
  16. spring.datasource.secondary.min-idle=0
  17. #Spring Data JPA
  18. spring.jpa.database=MYSQL
  19. spring.jpa.show-sql=true
  20. spring.jpa.hibernate.ddl-auto=update
  21. # Naming strategy
  22. spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy
  23. # stripped before adding them to the entity manager)
  24. spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect

 连接数据库字段做了一些更改,变了之后springboot就不认识这东西,不知道它是数据库的信息配置,因此我们需要重新定义。 
首先,定义数据源,并且注明一个主数据源,一个从数据源。直接在java目录下,直接在启动类同级新建一个DataSourceConfig.java文件。

  1. import org.springframework.beans.factory.annotation.Qualifier;
  2. import org.springframework.boot.autoconfigure.jdbc.DataSourceBuilder;
  3. import org.springframework.boot.context.properties.ConfigurationProperties;
  4. import org.springframework.context.annotation.Bean;
  5. import org.springframework.context.annotation.Configuration;
  6. import org.springframework.context.annotation.Primary;
  7. import javax.sql.DataSource;
  8. /**
  9. * @ClassName DataSourcesConfig
  10. * @Description TODO
  11. * @Author duyuanyuan
  12. * @Date 2019/1/311:05
  13. * @Version 1.0
  14. **/
  15. @Configuration
  16. public class DataSourcesConfig {
  17. //配置主数据源@Primary表示主数据源
  18. @Bean(name = "primaryDataSource")
  19. @Qualifier("primaryDataSource")
  20. @Primary
  21. @ConfigurationProperties(prefix="spring.datasource.primary")//此处要与配置连接数据库信息一致
  22. public DataSource primaryDataSource() {
  23. System.out.println("primary db built");
  24. return DataSourceBuilder.create().build();
  25. }
  26. //配置从数据源
  27. @Bean(name = "secondaryDataSource")
  28. @Qualifier("secondaryDataSource")
  29. @ConfigurationProperties(prefix="spring.datasource.secondary")//此处要与配置连接数据库信息一致
  30. public DataSource secondaryDataSource() {
  31. System.out.println("secondary db built");
  32. return DataSourceBuilder.create().build();
  33. }
  34. }

 这样就相当于告诉程序,程序要用到两个数据库,于是程序就去连接这两个数据库。怎么连接呢,默认的连接已经行不通了,因此,对于每个数据库还需要有一个定义文件告诉程序如何去连接它。 
同样,我们在启动类同级目录新建两个数据库定义文件PrimaryConfig.java与SecondaryConfig.java,分别定义主数据库与从数据库。新建从数据源配置类SecondaryConfig.java

  1. import org.springframework.beans.factory.annotation.Autowired;
  2. import org.springframework.beans.factory.annotation.Qualifier;
  3. import org.springframework.boot.autoconfigure.orm.jpa.JpaProperties;
  4. import org.springframework.boot.orm.jpa.EntityManagerFactoryBuilder;
  5. import org.springframework.context.annotation.Bean;
  6. import org.springframework.context.annotation.Configuration;
  7. import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
  8. import org.springframework.orm.jpa.JpaTransactionManager;
  9. import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
  10. import org.springframework.transaction.PlatformTransactionManager;
  11. import org.springframework.transaction.annotation.EnableTransactionManagement;
  12. import javax.persistence.EntityManager;
  13. import javax.sql.DataSource;
  14. import java.util.Map;
  15. /**
  16. * @ClassName SecondaryConfig
  17. * @Description TODO
  18. * @Author duyuanyuan
  19. * @Date 2019/1/311:10
  20. * @Version 1.0
  21. **/
  22. @Configuration
  23. @EnableTransactionManagement
  24. @EnableJpaRepositories(
  25. entityManagerFactoryRef="entityManagerFactorySecondary",
  26. transactionManagerRef="transactionManagerSecondary",
  27. basePackages= { "com.aaa.Repository.secondary" }) //设置Repository所在位置
  28. public class SecondaryConfig {
  29. @Autowired
  30. private JpaProperties jpaProperties;
  31. @Autowired @Qualifier("secondaryDataSource")
  32. private DataSource secondaryDataSource;
  33. @Bean(name = "entityManagerSecondary")
  34. public EntityManager entityManager(EntityManagerFactoryBuilder builder) {
  35. return entityManagerFactorySecondary(builder).getObject().createEntityManager();
  36. }
  37. @Bean(name = "entityManagerFactorySecondary")
  38. public LocalContainerEntityManagerFactoryBean entityManagerFactorySecondary (EntityManagerFactoryBuilder builder) {
  39. return builder
  40. .dataSource(secondaryDataSource)
  41. .properties(getVendorProperties(secondaryDataSource))
  42. .packages("com.aaa.Entity") //设置实体类所在位置
  43. .persistenceUnit("secondaryPersistenceUnit")
  44. .build();
  45. }
  46. private Map<String, String> getVendorProperties(DataSource dataSource) {
  47. return jpaProperties.getHibernateProperties(dataSource);
  48. }
  49. @Bean(name = "transactionManagerSecondary")
  50. PlatformTransactionManager transactionManagerSecondary(EntityManagerFactoryBuilder builder) {
  51. return new JpaTransactionManager(entityManagerFactorySecondary(builder).getObject());
  52. }
  53. }

 

 

 

建主数据源配置类PrimaryConfig.java

  1. import org.springframework.beans.factory.annotation.Autowired;
  2. import org.springframework.beans.factory.annotation.Qualifier;
  3. import org.springframework.boot.autoconfigure.orm.jpa.JpaProperties;
  4. import org.springframework.boot.orm.jpa.EntityManagerFactoryBuilder;
  5. import org.springframework.context.annotation.Bean;
  6. import org.springframework.context.annotation.Configuration;
  7. import org.springframework.context.annotation.Primary;
  8. import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
  9. import org.springframework.orm.jpa.JpaTransactionManager;
  10. import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
  11. import org.springframework.transaction.PlatformTransactionManager;
  12. import org.springframework.transaction.annotation.EnableTransactionManagement;
  13. import javax.persistence.EntityManager;
  14. import javax.sql.DataSource;
  15. import java.util.Map;
  16. /**
  17. * @ClassName PrimaryConfig
  18. * @Description TODO
  19. * @Author duyuanyuan
  20. * @Date 2019/1/311:07
  21. * @Version 1.0
  22. **/
  23. @Configuration
  24. @EnableTransactionManagement
  25. @EnableJpaRepositories(
  26. entityManagerFactoryRef="entityManagerFactoryPrimary",
  27. transactionManagerRef="transactionManagerPrimary",
  28. basePackages= { "com.aaa.Repository" }) //设置Repository所在位置
  29. public class PrimaryConfig {
  30. @Autowired @Qualifier("primaryDataSource")
  31. private DataSource primaryDataSource;
  32. @Primary
  33. @Bean(name = "entityManagerPrimary")
  34. public EntityManager entityManager(EntityManagerFactoryBuilder builder) {
  35. return entityManagerFactoryPrimary(builder).getObject().createEntityManager();
  36. }
  37. @Primary
  38. @Bean(name = "entityManagerFactoryPrimary")
  39. public LocalContainerEntityManagerFactoryBean entityManagerFactoryPrimary (EntityManagerFactoryBuilder builder) {
  40. return builder
  41. .dataSource(primaryDataSource)
  42. .properties(getVendorProperties(primaryDataSource))
  43. .packages("com.aaa.Entity") //设置实体类所在位置
  44. .persistenceUnit("primaryPersistenceUnit")
  45. .build();
  46. }
  47. @Autowired(required=false)
  48. private JpaProperties jpaProperties;
  49. private Map<String, String> getVendorProperties(DataSource dataSource) {
  50. return jpaProperties.getHibernateProperties(dataSource);
  51. }
  52. @Primary
  53. @Bean(name = "transactionManagerPrimary")
  54. public PlatformTransactionManager transactionManagerPrimary(EntityManagerFactoryBuilder builder) {
  55. return new JpaTransactionManager(entityManagerFactoryPrimary(builder).getObject());
  56. }
  57. }

到这里spring boot jpa多数据源已经配置完成,正常写Controller Service  Repository,根据业务需求可以在Service实现类注入不同数据源下的Repository即可。
 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/article/detail/52309
推荐阅读
相关标签
  

闽ICP备14008679号