弹簧和持久性单元与jboss

时间:2014-04-29 05:32:22

标签: java spring hibernate struts2 jboss

我的项目最初开发使用的是持久性单元和项目是spring,Struts2是hibernate整合的一个。现在我需要使用jboss连接池和持久性单元。 任何人都可以指导我以最短的方式在该要求中转换项目。 当前的spring.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">


<bean
    class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
    <property name="location">
        <value>properties/database.properties</value>
    </property>
</bean>
<bean id="springdatasource"

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

<bean id="sessionFactory"
    class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">

    <property name="dataSource">
        <ref bean="springdatasource" />
    </property>

    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.OracleDialect</prop>
            <prop key="hibernate.format_sql">true</prop>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
            <prop key="hibernate.show_sql">true</prop>
        </props>
    </property>

    <property name="annotatedClasses">
        <list>

            <value>model.AtOrganisation</value>

            <value>model.AtDivision</value>



        </list>
    </property>

</bean>



<bean id="orgdao" class="dao.OrganisationDaoImp">
    <property name="sessionfactory" ref="sessionFactory" />
</bean>
<bean id="divdao" class="dao.DevisionDaoImpl">
    <property name="sessionfactory" ref="sessionFactory" />
</bean>
<bean id="empAction" class="action.OraganisationAction">
    <property name="orgdao" ref="orgdao" />
</bean>
<bean id="empAction2" class="action.DevisionAction">
    <property name="orgdao" ref="orgdao" />
</bean>
<bean id="divAction" class="action.DevisionAction">
    <property name="divdao" ref="divdao" />
</bean>

示例DAO类

public class DevisionDaoImpl implements DevisionDao {


private SessionFactory sessionfactory;

public void setSessionfactory(SessionFactory sessionfactory) {
    this.sessionfactory = sessionfactory;
}
@Override
public List showDiv() {
    // TODO Auto-generated method stub
    return null;
}

@Override
public void addDiv(AtDivision div) {
    Session session = sessionfactory.openSession();
    Transaction tx = null;
    try {
        tx = session.beginTransaction();
        session.saveOrUpdate(div);
        tx.commit();
        //System.out.println("after save : " + org.getAoId());
    } catch (Exception e) {
        if (tx != null) {
            tx.rollback();
        }
        e.printStackTrace();
    } finally {
        session.close();
    }
}

}

1 个答案:

答案 0 :(得分:0)

1:更改数据源配置以使用jboss数据源。这可以这样做:

<jee:jndi-lookup id="springdatasource" jndi-name="your-de-jndi-name" />

2:使用spring transaction manager添加事务管理器来控制事务:

<bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
  <property name="sessionFactory" ref="sessionFactory" />
</bean>

3:为spring事务添加注释支持。将其添加到您的配置中:

<tx:annotation-driven transaction-manager="transactionManager" />

4:最后用@Transactional

装饰你的Dao类