HSQL入门(三)Memory-Only 内存模式

此模式和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)等等。需要更加深入的学习,请参考其提供的文档。一百多页呦。呵呵。

你可能感兴趣的:(oracle,sql,mysql,jdbc,HSQLDB)