Spring多个SessionFactory配置?

时间:2014-01-03 21:22:10

标签: java spring hibernate sessionfactory spring-orm

我正在尝试使用spring配置两个sessionFactories。我的配置看起来类似于列出的here

这是我的config.xml

<bean id="dataSource"
    class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="url">
        <value>${hibernate.connection.url}</value>
    </property>
    <property name="driverClassName">
        <value>${hibernate.connection.driver_class}</value>
    </property>
    <property name="username">
        <value>${hibernate.connection.username}</value>
    </property>
    <property name="password">
        <value>${hibernate.connection.password}</value>
    </property>
</bean>

<bean id="sessionFactory"
    class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
    <property name="dataSource">
        <ref bean="dataSource" />
    </property>
    <property name="mappingResources">
        <list>
            ...Mappings
        </list>
    </property>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">
                ${hibernate.dialect}
            </prop>
            <prop key="hibernate.jdbc.batch_size">${hibernate.jdbc.batch_size}</prop>
            <prop key="hibernate.cache.use_query_cache">true</prop>
            <prop key="hibernate.default_batch_fetch_size">${hibernate.default_batch_fetch_size}</prop>
            <prop key="hibernate.c3p0.min_size">${hibernate.c3p0.min_size}</prop>
            <prop key="hibernate.c3p0.max_size">${hibernate.c3p0.max_size}</prop>
            <prop key="hibernate.c3p0.timeout">${hibernate.c3p0.timeout}</prop>
            <prop key="hibernate.c3p0.max_statements">${hibernate.c3p0.max_statements}</prop>
            <prop key="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</prop>
        </props>
    </property>
</bean>

<bean id="dataSource2"
    class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="url">
        <value>${hibernate.connection.mirror_url}</value>
    </property>
    <property name="driverClassName">
        <value>${hibernate.connection.driver_class}</value>
    </property>
    <property name="username">
        <value>${hibernate.connection.mirror_username}</value>
    </property>
    <property name="password">
        <value>${hibernate.connection.mirror_password}</value>
    </property>
</bean>

<bean id="sessionFactory2"
    class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
    <property name="dataSource">
        <ref bean="dataSource2" />
    </property>
    <property name="mappingResources">
        <list>
            ...Mappings
        </list>
    </property>
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">
                ${hibernate.dialect}
            </prop>
            <prop key="hibernate.jdbc.batch_size">${hibernate.jdbc.batch_size}</prop>
            <prop key="hibernate.cache.use_query_cache">true</prop>
            <prop key="hibernate.default_batch_fetch_size">${hibernate.default_batch_fetch_size}</prop>
            <prop key="hibernate.c3p0.min_size">${hibernate.c3p0.min_size}</prop>
            <prop key="hibernate.c3p0.max_size">${hibernate.c3p0.max_size}</prop>
            <prop key="hibernate.c3p0.timeout">${hibernate.c3p0.timeout}</prop>
            <prop key="hibernate.c3p0.max_statements">${hibernate.c3p0.max_statements}</prop>
            <prop key="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</prop>
        </props>
    </property>
</bean>

然后每个dao获得一个不同的sessionFactory

<bean id="productDao"
    class="test.dao.ProductDaoHibernate">
    <property name="sessionFactory"><ref bean="sessionFactory" /></property>
</bean>

<bean id="currencyDao"
    class="test.dao.CurrencyDaoHibernate">
    <property name="sessionFactory"><ref bean="sessionFactory2" /></property>
</bean>

此配置在添加到上下文

时会被加载

的web.xml:

<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>/WEB-INF/classes/test-data.xml /WEB-INF/classes/test-services.xml ... </param-value>
</context-param>

问题显示每当我启动服务器时,每个sessionFactory都会生成,但是在第二个结束时会出现这个问题:

[INFO] [org.springframework.beans.factory.support.DefaultListableBeanFactory]:? - Destroying singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@97aaa6: defining beans [... Many elements...]; root of factory hierarchy
[INFO] [org.springframework.orm.hibernate3.LocalSessionFactoryBean]:? - Closing Hibernate SessionFactory
[INFO] [org.hibernate.impl.SessionFactoryImpl]:? - closing
[INFO] [org.springframework.orm.hibernate3.LocalSessionFactoryBean]:? - Closing Hibernate SessionFactory
[INFO] [org.hibernate.impl.SessionFactoryImpl]:? - closing

如果您需要更多信息,请咨询

2 个答案:

答案 0 :(得分:0)

实际上这应该是评论,但没有足够的声誉(需要50分)

您似乎正在尝试创建两个完全相同配置的不同bean ID。一种方法是确定是否需要指向相同配置的2个不同会话对象。其他方法是尝试在不同文件中添加配置并单独加载。请添加您尝试在代码中使用这些配置的方式。

答案 1 :(得分:0)

spring4.2&amp; hibernate5.1.5

@Bean
public LocalSessionFactoryBean aaaSessionFactory() {
    LocalSessionFactoryBean localSessionFactoryBean = new LocalSessionFactoryBean();
    localSessionFactoryBean.setDataSource(smsDataSource());
    localSessionFactoryBean.setHibernateProperties(getHibernateProperties());
    localSessionFactoryBean.setPackagesToScan(new String[]{"com.xxx.pojo"});
    localSessionFactoryBean.setPhysicalNamingStrategy(new CustomNamingStrategy());
    localSessionFactoryBean.setEntityInterceptor(new DynamicTableInterceptor());
    return localSessionFactoryBean;
}

@Bean
public LocalSessionFactoryBean bbbSessionFactoryMultiple() {
    LocalSessionFactoryBean localSessionFactoryBean = new LocalSessionFactoryBean();
    localSessionFactoryBean.setDataSource(smsDataSource());
    localSessionFactoryBean.setHibernateProperties(getHibernateProperties());
    localSessionFactoryBean.setPackagesToScan(new String[]{"com.xxx.pojo"});
    localSessionFactoryBean.setPhysicalNamingStrategy(new CustomNamingStrategy());
    localSessionFactoryBean.setEntityInterceptor(new DynamicTableInterceptor());
    return localSessionFactoryBean;
}


public class xxx extends HibernateDaoSupport{***
    @Autowired
    public void anyMethodName(@Qualifier("aaaSessionFactory")     SessionFactory sessionFactory) {
        setSessionFactory(sessionFactory);
    }