首页 > 解决方案 > 进程内模式 hsqldb 不创建表也不保存值

问题描述

我的主要课程:

public static void main(String[] args) {
    Connection con = null;
    Statement stmt = null;
    int result = 0;
    try {
        Class.forName("org.hsqldb.jdbc.JDBCDriver");
        con = DriverManager.getConnection("jdbc:hsqldb:file:data", "SA", "SA");
        stmt = con.createStatement();
        result = stmt.executeUpdate("CREATE TABLE surr (ID INTEGER IDENTITY NOT NULL, NAME VARCHAR(40) NOT NULL ) ");
        con.commit();
    } catch (Exception e) {
        e.printStackTrace(System.out);
    }
    System.out.println(result + " rows effected");
    System.out.println("Rows inserted successfully");
}

Pom xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>


    <groupId>org.example</groupId>
    <artifactId>untitled</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <dependency>
            <groupId>org.hsqldb</groupId>
            <artifactId>hsqldb</artifactId>
            <version>2.5.0</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

自动生成的 data.script 文件绝对拒绝创建表。曾经可以创建一个表,甚至可以插入一行,但仅此而已。我发现如果你将行插入到一个奇迹般创建的表中,行被创建,它们可以在当前连接中获取,但是当 main 方法完成时,更改并没有保存在数据中。脚本。可以做些什么呢?

标签: javajdbchsqldb

解决方案


有多种方法可以解决问题。

默认设置的写入延迟为 500 毫秒。如果您希望提交立即将更改写入磁盘,请更改写入延迟:

con = DriverManager.getConnection("jdbc:hsqldb:file:data;hsqldb.write_delay=false", "SA", "SA");

如果您按照注释中的建议关闭连接,则会写入所有提交的更改。

一个不错的选择是在程序结束时关闭数据库:

stmt.executeUpdate("SHUTDOWN");

当您重新启动程序并连接到数据库时,关闭以一种加载时间更短的形式写入所有数据库文件。


推荐阅读