如何从一个数据源读取对象并使用spring数据写入另一个数据源?

时间:2017-11-25 06:26:46

标签: java spring-data-jpa

我有一个配置类:

@SpringBootConfiguration
    @ComponentScan(basePackages = "vap")

    public class AppConfig {


        Logger logger = LoggerFactory.getLogger(this.getClass());
        public AppConfig() {
        }

        @Bean
        public ServerRuntime runtime() {
            ServerRuntime runtime = ServerRuntime.builder().addConfig("cayenne-project.xml").build();
            return runtime;
        }

        @Bean
        public ObjectContext getContext(@Autowired ServerRuntime serverRuntime) {
            return serverRuntime.newContext();
        }


        @Bean(name = "pgDataSource")
        public DataSource getDataSource() {
            Properties props = new Properties();
            props.setProperty("user", "postgres");
            props.setProperty("password", "");
            PoolConfiguration configuration = new PoolProperties();
            configuration.setDbProperties(props);
            configuration.setUrl("jdbc:postgresql://localhost/mikro00");
            configuration.setDriverClassName("org.postgresql.Driver");
            DataSource dataSource = new org.apache.tomcat.jdbc.pool.DataSource(configuration);
            return dataSource;
        }

        @Bean(name = "hsqldbDataSource")
        public DataSource getHSQLDataSource() {
            Properties props = new Properties();
            props.setProperty("user", "sa");
            props.setProperty("password", "");


            PoolConfiguration configuration = new PoolProperties();
            configuration.setDbProperties(props);
            configuration.setUrl("jdbc:h2:file:./outbase");
            configuration.setDriverClassName("org.h2.Driver");
            DataSource dataSource = new org.apache.tomcat.jdbc.pool.DataSource(configuration);
            return dataSource;
        }


    }

我的PGConfig.java

@Configuration
@EnableTransactionManagement
public class PGConfig {

    @Primary
    @Bean(name = "entityManagerFactoryPG")
    public LocalContainerEntityManagerFactoryBean entityManagerFactory(EntityManagerFactoryBuilder builder, @Qualifier(value = "pgDataSource") DataSource dataSource) {
        LocalContainerEntityManagerFactoryBean vap = builder.dataSource(dataSource)
                .packages("vap")
                .build();
        JpaVendorAdapter jpaVendorAdapter = new HibernateJpaVendorAdapter();
        vap.setJpaVendorAdapter(jpaVendorAdapter);
        return vap;
    }

    @Primary
    @Bean(name = "transactionManagerPG")
    public PlatformTransactionManager transactionManager(
            @Qualifier("entityManagerFactory") EntityManagerFactory
                    entityManagerFactory
    ) {
        return new JpaTransactionManager(entityManagerFactory);
    }

}

我的H2Config.java

@Configuration
@EnableTransactionManagement
public class H2Config {

    @Primary
    @Bean(name = "dataSource")
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource dataSource(){
        return DataSourceBuilder.create().build();
    }

    @Primary
    @Bean(name = "entityManagerFactory")
    public LocalContainerEntityManagerFactoryBean entityManagerFactory(EntityManagerFactoryBuilder builder, @Qualifier(value = "hsqldbDataSource") DataSource dataSource){
        LocalContainerEntityManagerFactoryBean vap = builder.dataSource(dataSource)
                .packages("vap")
                .build();
        JpaVendorAdapter jpaVendorAdapter = new HibernateJpaVendorAdapter();
        vap.setJpaVendorAdapter(jpaVendorAdapter);
        return vap;

    }

    @Primary
    @Bean(name = "transactionManagerH2")
    public PlatformTransactionManager transactionManager(
            @Qualifier("entityManagerFactory") EntityManagerFactory
                    entityManagerFactory
    ) {
        return new JpaTransactionManager(entityManagerFactory);
    }

}

KlientRepository

@Repository
public interface KlientRepository extends CrudRepository<Klient,Integer> {
}

如何从一个存储库读取Klient并写入另一个存储库。我需要从PG读取,处理数据并保存到h2。我无法找到具有不同数据源的两个存储库对象,或者只是使用具体数据源创建存储库对象

1 个答案:

答案 0 :(得分:1)

你的代码中有很多东西,你只需要做一些微调就可以了

  1. 使用Datasource,EntityManagerFactory和TransactionManager
  2. 的bean声明创建两个配置类
  3. 将两者中的一个标记为主要
  4. 创建两个模型类(每个数据库模型一个)
  5. 在两个不同的包中创建两个存储库类**(非常重要)**
  6. 在您的服务类中自动装配两个存储库,从一个数据库中读取,操作并保存到其他数据库。
  7. 只有代码中缺少的是你需要告诉Spring哪个Repository类应该使用哪个EntityManager / Datasource(因为你有两个)。这可以通过注释@EnableJpaRepositories(basepackages=...)来完成。在每个配置类上使用此批注,basePackages指示您的存储库类