`
zhyt710
  • 浏览: 203319 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

跑跑hsqldb

阅读更多

目前hsqldb应该上不了大的场合, 但是它的纯java可嵌入轻量级的特性,确实吸引这很多人。尤其想到在测试方面应该会给项目带来一定的方便。于是今天稍微的看看相关文档, 并进行了应用测试。

测试一下hsql的使用, 注意把从官网下载的分发包中的hsqldb.jar包包括在你的classpath中

TestConnector.java

package zhangyt.db.hsqldb;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class TestConnector {

	/**
	 * @param args
	 */
	public static void main(String[] args) throws Exception {
		
		Class.forName("org.hsqldb.jdbcDriver");
		//连接url的前缀
		//1. jdbc:hsqldb:                       内存运行模式
		//2. jdbc:hsqldb:file:                  标准模式
		//3. jdbc:hsqldb:hsql://localhost/xdb   服务模式 现在可以验证这个可以保持持久化
		Connection conn = DriverManager.getConnection("jdbc:hsqldb:file:"
                + "testData/testDB",      // 数据库的文件名
                "sa",                     // 用户名
                "");                      // 密码
		
		Statement st = conn.createStatement();
		
		//建立表格
		st.executeUpdate("create table testTable(" +
				"id int," +
				"name varchar(20))");
		
		//插入一条数据
		int count = st.executeUpdate("insert into testTable values(1, 'zhangyt')");
		System.out.println("你插入了 " + count + " 条数据");
		
		//检索数据打印所有数据
		ResultSet rs = st.executeQuery("select * from testTable");
		while(rs.next()) {
			int i = rs.getInt("id");
			String name = rs.getString("name");
			System.out.println(i + " " + name);
		}
		
		//更新数据
		count = st.executeUpdate("update testTable set name = 'zhangyantao'");
		System.out.println("你更新了 " + count + " 条数据");
		
		//检索数据打印所有数据
		rs = st.executeQuery("select * from testTable");
		while(rs.next()) {
			int i = rs.getInt("id");
			String name = rs.getString("name");
			System.out.println(i + " " + name);
		}
		
		rs.close();
		st.close();
		conn.close();
		
	}

}

 

 

HsqldbUtil.java

package zhangyt.db.hsqldb;

import java.util.Scanner;

import org.hsqldb.Server;

public class HsqldbUtil {

	public static Server startServer() {
		
	        Server server = new Server();
	        server.setDatabaseName(0, "testDB");
	        server.setDatabasePath(0, "testData" + "/testDB");
	        //if (port != -1)
	        //    server.setPort(port);

	        server.setSilent(true);
	        
	        server.start();
	        // 等待Server启动
	     try {
	            Thread.sleep(800);
	        }
	        catch (InterruptedException e) {
	            // do nothing
	        }

                        return server;		
	}
	
	/**
	 * @param args
	 */
	public static void main(String[] args) {
		
		//启动数据库
		Server server = HsqldbUtil.startServer();
		
		Scanner snr = new Scanner(System.in);
		System.out.println("数据库服务已经启动, 输入 exit 停止服务");
		while(!snr.nextLine().equals("exit")) {
		}
        
		//关闭数据库
		server.shutdown();
		
	}

}

 

问题点: 在标准模式中并没有看到能够把数据持久化的文件。 而只是和内存模式相同?

 

要想在web测试中用此数据库的服务模式(保证持久化), 可以定义监听servlet, 在web服务器启动的时候,开启hsqldb数据哭服务,在web服务结束的时候关闭hsqldb服务。代码可以参考如下代码骨架

public class HsqldbListener implements ServletContextListener {


    public void contextInitialized(ServletContextEvent sce) {
         /**
         Server server = new Server();
         server.setDatabaseName(0, "testDB");
         server.setDatabasePath(0, "testData" + "/testDB");
         server.setSilent(true);
         server.start();
         **/
         //在这个方法中启动服务
    }

   
    public void contextDestroyed(ServletContextEvent sce) {
        /** 最原始的关闭方法
        String dbName = Config.getString("metawork.hsql.dbName");
        Connection conn = null;
        try {
            Class.forName("org.hsqldb.jdbcDriver");
            conn = DriverManager.getConnection("jdbc:hsqldb:hsql://localhost:/" + dbName,
                    "sa", "");
            Statement stmt = conn.createStatement();
            stmt.executeUpdate("SHUTDOWN;");
        } catch (Exception e) {
            //do nothing
        }
        **/
        //关闭服务
     //server.shutdown(); 如果存在服务引用对象可以直接这样

    }
}

 

 

当然, 在单元测试的时候, 用什么样的方法来启动服务, 各位自有妙法,不在这里多说

分享到:
评论

相关推荐

    hsqldb使用(转载)

    hsqldb确实是个好东西,对于系统演示,开发等都很方便。

    hsqldb jdbc driver

    hsqldb jdbc driver适合于hsqldb

    HSQLDB中文帮助文档

    Hsqldb 是一个优秀的轻量级开源的纯Java SQL 数据库。 大家可以从Hsqldb 官方网站(http://hsqldb.org)获取到Hsqldb 的发布包、源代码和文档。

    hsqldb实例源代码

    简单的创建两个例子,如何创建hsqldb,如何使用hsqldb查询数据等。

    HSQLDB 1.8.0

    HSQLDB 1.8.0

    hsqldb-1.7.1.jar

    数据库连接 hsqldb1.7.1.jar

    hsqldb-lib.zip

    hsqldb可能需要的额外jar包 Additional Jar files needed for hsqldb.

    hsqldb-2.3.2.zip

    hsqldb 2 3 2 zip HyperSQL是用Java编写的一款SQL关系数据库引擎 它的核心完全是多线程的 支持双向锁和MVCC 多版本并发控制 几乎完整支持ANSI 92 SQL 支持常见数据类型 最新版本增加了对BLOB和CLOB数据的支持 最高...

    hsqldb的最新版本

    hsqldb的最新1.9.0版本,支持windows操作系统

    hsqldb-2.4.0.zip

    hsqldb-2.4.0

    hsqldb 2.25

    hsqldb for jdk1.5因为hsqldb的2.0版本以上都是jdk1.6进行编译的,我提供的这个2.25版本的是jdk1.5编译的。

    HSQLDB中文手册

    HSQLDB中文手册

    HSQLDB快速连接数据库

    HSQLDB中文文档,能够提高数据的处理速度。

    hsqldb jar

    hsqldb jar

    HSQLDB用户手册

    HyperSQL User Guide HyperSQL Database Engine (HSQLDB) 2.2 hsqldb-2.2.9用户手册

    hsqldb-2.2.8数据库

    Hsqldb是一个开放源代码的JAVA数据库,其具有标准的SQL语法和JAVA接口,它可以自由使用和分发,非常简洁和快速。

    HSQLDB数据库

    HSQLDB数据库,经典啊

    hsqldb-2.5.0.jar

    hsqldb数据库下载,很好用,简易的内存数据库,特别适合初学者。

    hsqldb-2.5.0.zip

    开源数据库hsqldb最新版本2.5.0,含源代码及bin文件 Open-sourced database hsqldb2.5.0, including source code and bin file(stuctured in form of .BAT)

    hsqldb.jar

    hsqldb.jar

Global site tag (gtag.js) - Google Analytics