Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/html/74.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Spring mvc 在内存数据库中为@Autowired jdbcTemplate和h2多次执行runscript_Spring Mvc_H2 - Fatal编程技术网

Spring mvc 在内存数据库中为@Autowired jdbcTemplate和h2多次执行runscript

Spring mvc 在内存数据库中为@Autowired jdbcTemplate和h2多次执行runscript,spring-mvc,h2,Spring Mvc,H2,我继承了一个项目,正在尝试针对内存中的h2数据库运行一组集成测试。为了让它们传递一些表,需要创建关系和引用数据 我可以看出问题在于RUNSCRIPT中引用的脚本被多次执行,因此生成索引“XXX\u IDX”已经存在错误和其他冲突。那么,有没有办法强制脚本只运行一次,或者我需要一个外部数据库?脚本似乎在我假设的每个连接上都运行 属性文件 my.datasource.url=jdbc:h2:mem:my_db;DB_CLOSE_DELAY=-1;MODE=Oracle;MVCC=TRUE;INIT=

我继承了一个项目,正在尝试针对内存中的h2数据库运行一组集成测试。为了让它们传递一些表,需要创建关系和引用数据

我可以看出问题在于
RUNSCRIPT
中引用的脚本被多次执行,因此生成
索引“XXX\u IDX”已经存在
错误和其他冲突。那么,有没有办法强制脚本只运行一次,或者我需要一个外部数据库?脚本似乎在我假设的每个连接上都运行

属性文件

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"/>

默认bean作用域为singleton时,我认为这会起作用,但我想我遗漏了一些东西。另外,如果我切换到一个已经设置了表和引用数据的真实Oracle实例,测试都会通过。

在许多情况下,可以编写SQL脚本,这样就不会引发异常:

create table if not exists test(id int, name varchar(255));
create index if not exists test_idx on test(name);

我最终使用了另一种方法,因为我无法以一种可以毫无错误地重新应用的方式编写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>

在上下文初始化时执行一次


注意:为了简洁起见,省略了其他名称空间和bean。

谢谢。我已经做了一些类似的更改,但似乎我无法在Oracle中轻松地对序列执行相同的操作。我确实首先搜索了一个“创建或替换序列”:)如果可能的话,我希望避免重写所有现有的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>