プロジェクトを継承し、インメモリ 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 インスタンスに切り替えると、すべてのテストに合格します。