java - 没有 persistence.xml 的多个entityManagerFactory

标签 java spring entitymanager persistence.xml

我一直在一个使用 spring mvc 4 的项目中工作,并且 JPA 配置 bean 是在 java 类中创建的,没有 persistence.xml,就像下面的代码一样。

package test.conf;

import java.util.Properties;
import javax.persistence.EntityManagerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.jdbc.datasource.DriverManagerDataSource;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.orm.jpa.JpaVendorAdapter;
import org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean;
import org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter;
import org.springframework.transaction.annotation.EnableTransactionManagement;

@Configuration
@EnableTransactionManagement
public class JPAConfiguration {

    @Bean
    @Primary
    public LocalContainerEntityManagerFactoryBean entityManagerFactory() {
        LocalContainerEntityManagerFactoryBean factoryBean = new LocalContainerEntityManagerFactoryBean();
        JpaVendorAdapter vendorAdapter = new HibernateJpaVendorAdapter();

        factoryBean.setJpaVendorAdapter(vendorAdapter);
        factoryBean.setDataSource(dataSource());    

        Properties props = new Properties();
        props.setProperty("hibernate.dialect", "org.hibernate.dialect.MySQL5Dialect");
        props.setProperty("hibernate.show_sql", "false");
        props.setProperty("hibernate.hbm2ddl.auto", "update");

        factoryBean.setJpaProperties(props);
        String [] packages = {"test.model"};
        factoryBean.setPackagesToScan(packages);

        return factoryBean;
    }

    @Bean
    @Primary
    public DriverManagerDataSource dataSource() {

        DriverManagerDataSource dataSource = new DriverManagerDataSource();
        dataSource.setUsername("root");
        dataSource.setPassword("root");
        dataSource.setUrl("jdbc:mysql://localhost:3306/database");
        dataSource.setDriverClassName("com.mysql.jdbc.Driver");
        return dataSource;
    }

    @Bean
    @Primary
    public JpaTransactionManager transactionManager(EntityManagerFactory emf){
        return new JpaTransactionManager(emf);
    }

}

这工作正常,但现在,我们必须连接到第二个数据库 (ORACLE),并且需要第二个实体管理器工厂。我怎样才能做到这一点 ?我找到了在 persistence.xml 上创建第二个持久性单元的示例,但我在该项目中没有 persistence.xml。其他人教如何使用 Spring Boot 创建与多个数据源的连接,但这不是 Spring Boot 项目。

我尝试为另一个数据库创建第二个JPAConfiguration类,然后为每个entitymanagerfactorybean指定一个factoryBean.setPersistenceUnitName("");,但Spring似乎搞砸了,因为它总是初始化一个持久性单位两次。

最佳答案

您需要在属性中拥有第二个数据源详细信息

#second db ...
spring.secondDatasource.url = [url]
spring.secondDatasource.username = [username]
spring.secondDatasource.password = [password]
spring.secondDatasource.driverClassName = oracle.jdbc.OracleDriver

然后创建配置类,该类将具有使用第二个数据源的所有配置,并使用第二个数据源启用 jpa 存储库。

@Configuration
@EnableTransactionManagement
@EnableJpaRepositories(entityManagerFactoryRef = "secondEntityManagerFactory",
        transactionManagerRef = "secondTransactionManager",
        basePackages = {"com.server.second.repo"}
)
public class SecondDBConfiguration  

@Bean("secondDatasource")
@ConfigurationProperties(prefix="spring.secondDatasource")
public DataSource secondaryDataSource() {
return DataSourceBuilder.create().build();
}

@Bean(name = "secondEntityManagerFactory")
public LocalContainerEntityManagerFactoryBean
secondEntityManagerFactory(
        EntityManagerFactoryBuilder builder,
        @Qualifier("secondDatasource") DataSource dataSource
) {
    return
            builder
                    .dataSource(dataSource)
                    .packages("com.server.shadow.domain")
                    .persistenceUnit("shadow")
                    .build();
}
@Bean(name = "secondTransactionManager")
public PlatformTransactionManager secondTransactionManager(
        @Qualifier("secondEntityManagerFactory") EntityManagerFactory
                secondEntityManagerFactory
) {
    return new JpaTransactionManager(secondEntityManagerFactory);
}

关于java - 没有 persistence.xml 的多个entityManagerFactory,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49970919/

相关文章:

java - Spring Cloud Config Server 与云 kubernetes 的 ConfigMaps

java - 如何使用 JPA 提高更新数据的性能

java - 如何在android中使用opengl es绘制3d对象,以org.opencv.android.javacameraview作为背景

java - 在java中读取具有多个分隔符的文件行

java - WebSocketStompClient 不会连接到 SockJS 端点

java - 嵌套异常是 java.lang.NoClassDefFoundError : Could not initialize class com. my.util.HibernateUtil

java - Spring Cloud Stream Kafka 记录太大

jpa - EntityManager 何时提交?

java - EntityManager.remove 和 EntityManager.persist 上的 JPA 重复条目错误

java - Log4J2 以编程方式读取属性文件时不记录任何内容