企業分佈式微服務雲SpringCloud SpringBoot mybatis (十)Spring Boot多數據源配置與使用(Spring-data-jpa支持)

Spring-data-jpa支持

對於數據源的配置能夠沿用上例中DataSourceConfig的實現。html

新增對第一數據源的JPA配置,注意兩處註釋的地方,用於指定數據源對應的Entity實體和Repository定義位置,用@Primary區分主數據源。java

@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(
        entityManagerFactoryRef="entityManagerFactoryPrimary",
        transactionManagerRef="transactionManagerPrimary",
        basePackages= { "com.didispace.domain.p" }) //設置Repository所在位置
public class PrimaryConfig {

    @Autowired @Qualifier("primaryDataSource")
    private DataSource primaryDataSource;

    @Primary
    @Bean(name = "entityManagerPrimary")
    public EntityManager entityManager(EntityManagerFactoryBuilder builder) {
        return entityManagerFactoryPrimary(builder).getObject().createEntityManager();
    }

    @Primary
    @Bean(name = "entityManagerFactoryPrimary")
    public LocalContainerEntityManagerFactoryBean entityManagerFactoryPrimary (EntityManagerFactoryBuilder builder) {
        return builder
                .dataSource(primaryDataSource)
                .properties(getVendorProperties(primaryDataSource))
                .packages("com.didispace.domain.p") //設置實體類所在位置
                .persistenceUnit("primaryPersistenceUnit")
                .build();
    }

    @Autowired
    private JpaProperties jpaProperties;

    private Map<String, String> getVendorProperties(DataSource dataSource) {
        return jpaProperties.getHibernateProperties(dataSource);
    }

    @Primary
    @Bean(name = "transactionManagerPrimary")
    public PlatformTransactionManager transactionManagerPrimary(EntityManagerFactoryBuilder builder) {
        return new JpaTransactionManager(entityManagerFactoryPrimary(builder).getObject());
    }

}

  

新增對第二數據源的JPA配置,內容與第一數據源相似,具體以下:dom

@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(
        entityManagerFactoryRef="entityManagerFactorySecondary",
        transactionManagerRef="transactionManagerSecondary",
        basePackages= { "com.didispace.domain.s" }) //設置Repository所在位置
public class SecondaryConfig {

    @Autowired @Qualifier("secondaryDataSource")
    private DataSource secondaryDataSource;

    @Bean(name = "entityManagerSecondary")
    public EntityManager entityManager(EntityManagerFactoryBuilder builder) {
        return entityManagerFactorySecondary(builder).getObject().createEntityManager();
    }

    @Bean(name = "entityManagerFactorySecondary")
    public LocalContainerEntityManagerFactoryBean entityManagerFactorySecondary (EntityManagerFactoryBuilder builder) {
        return builder
                .dataSource(secondaryDataSource)
                .properties(getVendorProperties(secondaryDataSource))
                .packages("com.didispace.domain.s") //設置實體類所在位置
                .persistenceUnit("secondaryPersistenceUnit")
                .build();
    }

    @Autowired
    private JpaProperties jpaProperties;

    private Map<String, String> getVendorProperties(DataSource dataSource) {
        return jpaProperties.getHibernateProperties(dataSource);
    }

    @Bean(name = "transactionManagerSecondary")
    PlatformTransactionManager transactionManagerSecondary(EntityManagerFactoryBuilder builder) {
        return new JpaTransactionManager(entityManagerFactorySecondary(builder).getObject());
    }

}

  

完成了以上配置以後,主數據源的實體和數據訪問對象位於:com.didispace.domain.p,次數據源的實體和數據訪問接口位於:com.didispace.domain.s測試

分別在這兩個package下建立各自的實體和數據訪問接口ui

  • 主數據源下,建立User實體和對應的Repository接口
    @Entity
    public class User {
    
        @Id
        @GeneratedValue
        private Long id;
    
        @Column(nullable = false)
        private String name;
    
        @Column(nullable = false)
        private Integer age;
    
        public User(){}
    
        public User(String name, Integer age) {
            this.name = name;
            this.age = age;
        }
    
        // 省略getter、setter
    
    }
    public interface UserRepository extends JpaRepository<User, Long> {
    
    }
    

      

     

  • 從數據源下,建立Message實體和對應的Repository接口
    @Entity
    public class Message {
    
        @Id
        @GeneratedValue
        private Long id;
    
        @Column(nullable = false)
        private String name;
    
        @Column(nullable = false)
        private String content;
    
        public Message(){}
    
        public Message(String name, String content) {
            this.name = name;
            this.content = content;
        }
    
        // 省略getter、setter
    
    }
    public interface MessageRepository extends JpaRepository<Message, Long> {
    
    }
    

      

    接下來經過測試用例來驗證使用這兩個針對不一樣數據源的配置進行數據操做。this

    @RunWith(SpringJUnit4ClassRunner.class)
    @SpringApplicationConfiguration(Application.class)
    public class ApplicationTests {
    
    	@Autowired
    	private UserRepository userRepository;
    	@Autowired
    	private MessageRepository messageRepository;
    
    	@Test
    	public void test() throws Exception {
    
    		userRepository.save(new User("aaa", 10));
    		userRepository.save(new User("bbb", 20));
    		userRepository.save(new User("ccc", 30));
    		userRepository.save(new User("ddd", 40));
    		userRepository.save(new User("eee", 50));
    
    		Assert.assertEquals(5, userRepository.findAll().size());
    
    		messageRepository.save(new Message("o1", "aaaaaaaaaa"));
    		messageRepository.save(new Message("o2", "bbbbbbbbbb"));
    		messageRepository.save(new Message("o3", "cccccccccc"));
    
    		Assert.assertEquals(3, messageRepository.findAll().size());
    
    	}
    
    }
    

      

    源碼來源spa

相關文章
相關標籤/搜索