此模式和In-Process (Standalone)模式大同小异。区别之处就在于把
connection = DriverManager.getConnection("jdbc:hsqldb:file:D:/hsqldb/data/mydb", "sa", "");
换为:
connection = DriverManager.getConnection("jdbc:hsqldb:mem:aname", "sa", "");
即可。
当随即访问内存,数据库不固定时,可以采用内存的方式运行数据库,由于没有数据写到硬盘上,这种方式使用在应用数据和applets 和特殊应用的内部进程中使用。这里也把代码粘贴出来,以做备忘。
package com;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
import java.sql.ResultSet;
/**
* Created by IntelliJ IDEA
* User: Administrator
* Date: 2006-11-5
* Time: 17:44:19
*/
public class HsqlMain {
static Connection connection;
public static void main(String[] args) {
System.out.println("-----------------------------");
try {
Class.forName("org.hsqldb.jdbcDriver");
connection = DriverManager.getConnection("jdbc:hsqldb:mem:aname", "sa", "");
Statement stmt = null;
ResultSet rs = null;
stmt = connection.createStatement();
String sql1 = "create table dong_test(xh varchar(10));";
String sql2 = "insert into dong_test(xh) values('Tom'); insert into dong_test(xh) values('Mary')";
String sql3 = "select * from dong_test";
stmt.executeUpdate(sql1);
stmt.executeUpdate(sql2);
rs = stmt.executeQuery(sql3);
while (rs.next()) {
System.out.println(">>> " + rs.getString(1));
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
其实上面所述的只是Hsql的一个起步而已,里面有许多需要研究的东西。如表的类型(在String sql1 = "create table dong_test(xh varchar(10));";这句话中,缺省创建的表是“内存模式”的表,也可以创建“Cached”类型,如:String sql1 = "create cached table dong_test(xh varchar(10));"; ),以及sql,事务和连接其他数据库(mysql,oracle)等等。需要更加深入的学习,请参考其提供的文档。一百多页呦。呵呵。