1

私は次のことを実装しようとしています: データベースに同じトランザクションで 2 つの異なるエンティティを追加する必要があります。エンティティごとに異なる DAO クラスとサービス クラスがあります。

public class InvoicesDAO  {
    @Autowired
    protected SessionFactory sessionFactory;

    public void save(Invoice object) {
        Session session = SessionFactoryUtils.getSession(sessionFactory, false);

        session.persist(object);
    }
}

public class RequestsDAO {
    @Autowired
    protected SessionFactory sessionFactory;

    public void save(Request object) {
        Session session = SessionFactoryUtils.getSession(sessionFactory, false);

        session.persist(object);
    }
}

public class InvoicesService {
    @Autowired
    private InvoicesDAO invoicesDAO;

    @Autowired
    private RequestsDAO requestsDAO;

    @Transactional
    public void add(Invoice object) throws HibernateException {
        invoicesDAO.save(object);
    }

    @Transactional
    public void updateAndGenerate(Invoice object1, Request object2) throws HibernateException {
        invoicesDAO.save(object1);
        requestsDAO.save(object2);
    }
}

構成:

<tx:annotation-driven transaction-manager="transactionManager" />
    <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="location" value="classpath:/hibernate.properties" />
    </bean>
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="${hibernate.connection.driver_class}" />
        <property name="url" value="${hibernate.connection.url}" />
        <property name="username" value="${hibernate.connection.username}" />
        <property name="password" value="${hibernate.connection.password}" />
    </bean>      
    <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="packagesToScan" value="com.ejl.butler.object.data" />
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">${hibernate.dialect}</prop>
                <prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
                <prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
                <prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop>
                <prop key="hibernate.cache.region.factory_class">${hibernate.cache.region.factory_class}</prop>
           </props>
        </property>
    </bean>
    <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />
    </bean>

<context:annotation-config />
    <context:component-scan base-package="com.service" />
    <bean id="invoicesDao" class="com.dao.InvoicesDAO" />
<bean id="requestsDao" class="com.dao.RequestsDAO" />

コントローラ:

//***
/**
     * Invoices access service
     */
    @Autowired
    private InvoicesService invoicesService;

        // objects creation
        invoicesService.updateAndGenerate(invoice, request);
//***

そのため、updateAndGenerate メソッドを呼び出して object2 に無効な値を渡そうとすると、object1 をロールバックせずに失敗します。どうすれば修正できますか?ありがとうございました

4

2 に答える 2

0

プロキシと関係があるとは思いません。ここではプロキシ オブジェクトは必要ありません。通常、シングルトン Bean 定義のプロキシ オブジェクトが必要なログイン サービスなどのインスタンスには、プロキシ オブジェクトが必要です。ただし、ロールバックできない唯一の方法は、トランザクションの伝播レベルが正しくない場合です。

Trasaction.REQUIRES_NEW を使用すると、dao.save はロールバックせず、外部トランザクションに関連付けられないため、ロールバックしません。

于 2013-12-30T09:50:35.193 に答える