进程内模式 hsqldb 不创建表也不保存值
in-process mode hsqldb doesn't create tables and doesn't save values
我的主要class:
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文件绝对拒绝创建tables。曾经可以创建 table,甚至可以插入一行,但仅此而已。我发现如果你将行插入到一个奇迹般创建的 table 中,这些行被创建,它们可以在当前连接中获取,但是当 main 方法完成时,更改不会保存在数据中。脚本。有什么办法吗?
有多种方法可以解决这个问题。
默认设置的写入延迟为 500 毫秒。如果你想让提交立即将更改写入磁盘,请更改写入延迟:
con = DriverManager.getConnection("jdbc:hsqldb:file:data;hsqldb.write_delay=false", "SA", "SA");
如果您按照评论中的建议关闭连接,则会写入所有已提交的更改。
一个不错的选择是在程序结束时也关闭数据库:
stmt.executeUpdate("SHUTDOWN");
关机以一种形式写入所有数据库文件,在您重新启动程序并连接到数据库时加载时间更短。
我的主要class:
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文件绝对拒绝创建tables。曾经可以创建 table,甚至可以插入一行,但仅此而已。我发现如果你将行插入到一个奇迹般创建的 table 中,这些行被创建,它们可以在当前连接中获取,但是当 main 方法完成时,更改不会保存在数据中。脚本。有什么办法吗?
有多种方法可以解决这个问题。
默认设置的写入延迟为 500 毫秒。如果你想让提交立即将更改写入磁盘,请更改写入延迟:
con = DriverManager.getConnection("jdbc:hsqldb:file:data;hsqldb.write_delay=false", "SA", "SA");
如果您按照评论中的建议关闭连接,则会写入所有已提交的更改。
一个不错的选择是在程序结束时也关闭数据库:
stmt.executeUpdate("SHUTDOWN");
关机以一种形式写入所有数据库文件,在您重新启动程序并连接到数据库时加载时间更短。