1

PostgreSQL と共に Spring JDBC テンプレートを使用しています。以下は私の構成データソースとトランザクション設定です:

<bean id="databasePropertyConfigurer"
          class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"
          p:location="/WEB-INF/config/database.properties" />

    <bean id="dataSource"
          class="org.springframework.jdbc.datasource.DriverManagerDataSource"
          p:driverClassName="${database.driverClassName}"
          p:url="${database.url}"
          p:username="${database.username}"
          p:password="${database.password}" />

    <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>

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

私のビジネスレイヤーでは、次のことを行っています。

@Transactional(rollbackFor=Exception.class)
@RequiresPermissions("hc:patient_createInvoice")
public Long createInvoice(Invoice invoice, List<InvoiceItem> items) throws ValidationException, NetAmountMismatchException, PatientInvoiceException
{
       try{
            dao1.insert(invoice);
       }
       catch(DataAccessException x){
            throw new PatientInvoiceException(x);
       }

       try{
            somevalidation(invoiceItem);    // Causes validation exception
            dao2.insert(invoiceItems);
       }
       catch(DataAccessException x){
       throw new PatientInvoiceException(x);
   }
}

そんな感じ。私が必要とするのは、このメソッドから例外 (チェック済みまたは未チェック) がスローされるたびに、これまでに実行されたすべてのデータベース更新をロールする必要があることです。

これは、現在のコードでは発生していません。

私は実際に何が欠けていますか?

4

1 に答える 1

4

デフォルトでは、Spring はチェックされていない例外のトランザクションのみをロールバックします。Springリファレンスマニュアルから:

Spring Framework のトランザクション インフラストラクチャ コードは、実行時の非チェック例外の場合にのみ、ロールバックのトランザクションをマークします。[...] トランザクション メソッドからスローされるチェック済み例外は、既定の構成ではロールバックされません。

ただし、Spring を構成して、チェックされた例外をロールバックすることもできます。次に例を示します。

<tx:advice id="txAdvice">
    <tx:attributes>
        <tx:method name="*" rollback-for="ValidationException, NetAmountMismatchException, PatientInvoiceException" />
    </tx:attributes>
</tx:advice>
于 2011-11-06T20:49:56.153 に答える