【问题标题】:Multiple entityManagerFactory without persistence.xml没有persistence.xml的多个entityManagerFactory
【发布时间】:2018-10-02 21:34:55
【问题描述】:

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

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 搞砸了,因为它总是初始化一个持久化单元两次。

【问题讨论】:

    标签: java spring entitymanager persistence.xml


    【解决方案1】:

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

    #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);
    }
    

    【讨论】:

    • Tks。我的配置文件中缺少一些参数,这导致了错误
    猜你喜欢
    • 2023-03-16
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-11-16
    • 2015-03-24
    • 2013-08-18
    • 2018-11-07
    相关资源
    最近更新 更多