相关疑难解决方法(0)

运行脚本以使用HSQLDB创建表

我使用hsqldb来运行需要数据库访问的单元测试.

目前,当我想为特定测试创建表时,我有以下代码:

private void createTable() {
    PreparedStatement ps;
    try {
        ps = getConnection().prepareStatement("CREATE TABLE T_DATE (ID NUMERIC PRIMARY KEY, DATEID TIMESTAMP)");
        ps.executeUpdate();
    } catch (SQLException e) {
        e.printStackTrace();
    }
}
Run Code Online (Sandbox Code Playgroud)

getConnection()方法检索在Spring上下文中定义的DataSource :

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName" value="org.hsqldb.jdbcDriver"/>
    <property name="url" value="jdbc:hsqldb:mem:memoryDB"/>
    <property name="username" value="SA"/>
    <property name="password" value=""/>
</bean>
Run Code Online (Sandbox Code Playgroud)

现在,我想从SQL脚本创建我的表(当然,这个脚本将包含多个表创建):

CREATE TABLE T_DATE_FOO (ID NUMERIC PRIMARY KEY, DATEID TIMESTAMP);
CREATE TABLE T_DATE_BAR (ID NUMERIC PRIMARY KEY, DATEID TIMESTAMP);
...
Run Code Online (Sandbox Code Playgroud)

我在HSQLDB文档中看到我可以让他在启动时运行脚本.但是,它不符合我的要求,因为我想在运行时运行脚本.

当然,我自己可以读取文件,对于每个SQL语句,我都运行一个ps.executeUpdate()命令,但我不想使用这种解决方案(除非没有其他解决方案). …

java sql hsqldb

7
推荐指数
1
解决办法
2万
查看次数

标签 统计

hsqldb ×1

java ×1

sql ×1