使用带有hibernate的AOP的Spring声明式事务,仍然使用默认的事务策略

时间:2013-02-27 06:23:53

标签: java spring

我正在尝试使用AOP和hibernate使用Spring事务管理来实现一个示例应用程序。 以下是我的配置文件

     <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xmlns:context="http://www.springframework.org/schema/context"
        xmlns:tx="http://www.springframework.org/schema/tx"
        xmlns:aop="http://www.springframework.org/schema/aop"
        xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
        http://www.springframework.org/schema/context 
        http://www.springframework.org/schema/context/spring-context-3.2.xsd
        http://www.springframework.org/schema/tx
        http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
        http://www.springframework.org/schema/aop
        http://www.springframework.org/schema/aop/spring-aop-3.2.xsd ">


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

    <!-- Beans Declaration -->
    <bean id="userDAO" class="com.wjb.daoimpl.UserDAOImpl">
        <property name="sessionFactory" ref="sessionFactory"></property>
    </bean>

         <tx:advice id="txAdvice" transaction-manager="txManager">
            <tx:attributes>
           <tx:method name="add*" read-only="true"/>
           </tx:attributes>
         </tx:advice>

         <aop:config>
           <aop:pointcut id="userOperation" expression="execution(* com.wjb.daoimpl.UserDAOImpl.*(..))"/>
         <aop:advisor advice-ref="txAdvice" pointcut-ref="userOperation"/>
         </aop:config>


<!-- Database Configuration -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="org.postgresql.Driver" />
<property name="url" value="jdbc:postgresql://10.12.30.180:4568/finitedb" />
<property name="username" value="finiteuser" />
<property name="password" value="finiteuser" />
</bean>

    <bean id="sessionFactory" 
     class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">

    <property name="annotatedClasses">
            <list>
                <value>com.wjb.user.model.User1</value>
            </list>
        </property>

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

    <property name="hibernateProperties">
       <props>
         <prop key="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</prop>
         <prop key="hibernate.show_sql">true</prop>
       </props>
    </property>
 </bean>


</beans>

这是我的impl类

public class UserDAOImpl {

    Session session;
    SessionFactory sessionFactory;

    public void setSessionFactory(SessionFactory sessionFactory){
        this.sessionFactory = sessionFactory;
        session = this.sessionFactory.openSession();
    }

    public void addUser(User1 user) {
        session.save(user);
    }

    public SessionFactory getSessionFactory() {
        return sessionFactory;
    }

}

当我运行应用程序时,我在日志中看到以下行,表明我的spring事务没有被调用。

  

2013年2月27日11:00:20 org.hibernate.dialect.Dialect INFO:   HHH000400:使用方言:org.hibernate.dialect.PostgreSQLDialect 2月   27,2013 11:00:20 AM   org.hibernate.engine.jdbc.internal.LobCreatorBuilder   useContextualLobCreation信息:HHH000423:禁用上下文LOB   创建为JDBC驱动程序报告的JDBC版本[3]不到2月4日,   2013 11:00:20 AM   org.hibernate.engine.transaction.internal.TransactionFactoryInitiator   initiateService INFO:HHH000399:使用默认事务策略   (直接JDBC事务)2013年2月27日上午11:00:20   org.hibernate.hql.internal.ast.ASTQueryTranslatorFactory信息:   HHH000397:使用ASTQueryTranslatorFactory

我错过了什么吗?请帮忙

1 个答案:

答案 0 :(得分:1)

来自vmoksha的Sunilkumar

将此行放入您的applicationcontext.xml

&LT; tx:注释驱动/&gt;


并且还在你的课堂上注释 的 @Transaction