3

プロジェクトを継承し、インメモリ h2 データベースに対して一連の統合テストを実行しようとしています。それらがいくつかのテーブルを渡すために、関係と参照データを作成する必要があります。

で参照されているスクリプトRUNSCRIPTが複数回実行されているため、Index "XXX_IDX" already existsエラーやその他の違反が発生しているという問題を確認できます。スクリプトを強制的に 1 回だけ実行する方法はありますか、それとも外部データベースが必要ですか? スクリプトは、私が想定しているすべての接続で実行されるようです

プロパティファイル

my.datasource.url=jdbc:h2:mem:my_db;DB_CLOSE_DELAY=-1;MODE=Oracle;MVCC=TRUE;INIT=RUNSCRIPT FROM 'classpath:/create-tables-and-ref-data.sql'

XML 構成

<bean id="myDataSource" class="org.apache.commons.dbcp.BasicDataSource">
    <property name="url" value="${my.datasource.url}"/>
    <!-- other properties for username, password etc... -->
</bean>

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

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="myDataSource"/>
</bean>

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

次のパターンの多くの Java クラス

@Component
public class SomethingDAOImpl implements SomethingDAO {
  @Autowired
  public SomethingDAOImpl(JdbcTemplate jdbcTemplate) {
    this.jdbcTemplate = jdbcTemplate;
  }
}

@Component
public class SomethingElseDAOImpl implements SomethingElseDAO {
  @Autowired
  public SomethingElseDAOImpl(JdbcTemplate jdbcTemplate) {
    this.jdbcTemplate = jdbcTemplate;
  }
}

デフォルトの Bean スコープがシングルトンであるため、これでうまくいくと思いましたが、何かが足りないと思います。また、すでにテーブルと参照データが設定されている実際の Oracle インスタンスに切り替えると、すべてのテストに合格します。

4

2 に答える 2

2

多くの場合、例外がスローされないように SQL スクリプトを作成することができます。

create table if not exists test(id int, name varchar(255));
create index if not exists test_idx on test(name);
于 2012-12-29T20:20:39.683 に答える
1

エラーなしで再適用できる方法で SQL を記述できなかったため、別のアプローチを使用することになりました。

<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:jdbc="http://www.springframework.org/schema/jdbc"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
    http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd">

    <jdbc:initialize-database data-source="myDataSource" enabled="true" ignore-failures="ALL">
        <jdbc:script location="classpath:create-and-alter-tables-first-then-add-test-data.sql" />
    </jdbc:initialize-database>
</beans>

これは、コンテキストの初期化時に 1 回実行されます。

注: 簡潔にするために、他の名前空間と Bean は省略されています。

于 2013-01-10T10:12:34.167 に答える