`
zhyt710
  • 浏览: 205710 次
  • 性别: 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支持多种运行模式,满足不同场景的需求。 1. **数据库实例创建** 创建HSQldb数据库...

    HSQLDB

    **HSQLDB(HyperSQL Database)详解** HSQLDB,全称HyperSQL数据库管理系统,是一款开源、轻量级、高性能的关系型数据库系统。它支持Java平台,并且完全遵循SQL标准,提供内存和磁盘两种存储方式,使得它适用于多种...

    hsqldb-2.2.8数据库

    **HSQldb 2.2.8 数据库详解** HSQldb(HyperSQL Database)是一款高效、轻量级且开源的Java数据库管理系统,它在IT领域中被广泛应用于开发、测试以及小型应用环境。HSQldb完全用Java编写,因此具有良好的跨平台性,...

    hsqldb 2.25

    **HSQldb 2.25 知识点详解** HSQldb,全称为HyperSQL Database,是一款开源、轻量级、嵌入式的关系型数据库管理系统。它支持标准的SQL语法,包括SQL-92和SQL:2003,且在Java环境中运行,无需依赖外部操作系统服务。...

    HSQLDB快速连接数据库

    ### HSQLDB快速连接数据库 #### 一、HSQLDB简介与特点 HSQLDB(HyperSQL Database)是一款优秀的轻量级开源纯Java SQL数据库管理系统。它被设计为易于集成到现有的Java应用环境中,尤其适合那些对性能和资源消耗有...

    hsqldb-2.5.0.jar

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

    hsqldb的最新版本

    HSQldb,全称HyperSQL Database,是一款开源的、轻量级的关系型数据库管理系统,尤其适合于嵌入式应用和开发测试环境。HSQldb完全用Java编写,因此具有跨平台性,能在任何支持Java的环境中运行,包括Windows操作系统...

    hsqldb-lib.zip

    《HSQldb与Java数据库连接详解》 HSQldb(HyperSQL Database)是一款开源、轻量级、嵌入式的关系型数据库管理系统,广泛应用于Java应用程序中。它支持SQL标准,提供单用户和多用户模式,并且可以运行在内存中或磁盘...

    HSQLDB中文帮助文档

    ### HSQLDB中文帮助文档知识点总结 #### 一、HSQLDB概述 - **定义**:HSQLDB(HyperSQL Database)是一款轻量级、开源的纯Java SQL数据库管理系统。它能够作为嵌入式数据库使用,也可以作为一个独立的服务器运行。 ...

    hsqldb jdbc driver

    hsqldb jdbc driver适合于hsqldb

    hsqldb demo

    **HSQldb 概述** HSQldb,全称 HyperSQL Database,是一个开源、轻量级、完全Java编写的数据库管理系统。它支持多种数据库模式,包括纯内存储存、文件系统存储以及网络服务器模式,使其在多种场景下都能发挥效用。...

    hsqldb包和使用说明

    HSQldb是一个开源的、轻量级的、嵌入式的Java数据库引擎,常用于开发测试环境和小型应用程序。它的全称是HyperSQL Database,能够支持SQL标准,包括SQL:2011。HSQldb因其小巧、快速和易用的特点,在Java开发中尤其受...

    开源数据库软件hsqldb

    《开源数据库软件HSQldb深度解析》 HSQldb,全称HyperSQL Database,是一款完全开源、免费的Java实现的关系型数据库管理系统(RDBMS),它支持多种运行环境,包括独立服务器模式、嵌入式模式以及Web应用。HSQldb因...

    HSQLDB 1.8.0

    《HSQLDB 1.8.0:轻量级数据库引擎的深度剖析》 HSQLDB,全称为HyperSQL Database,是一款开源、轻量级、高性能的关系型数据库管理系统,广泛应用于嵌入式系统和测试环境。HSQLDB 1.8.0是该数据库引擎的一个重要...

    hsqldb-2.3.3.zip

    《HSQldb 2.3.3:轻量级数据库引擎深度解析》 HSQldb,全称为HyperSQL Database,是一款开源、纯Java语言编写的轻量级关系型数据库管理系统,广泛应用于测试环境、嵌入式系统以及小型应用中。HSQldb 2.3.3是其稳定...

    HSQLDB中文手册

    ### HSQLDB中文手册知识点概览 #### 一、HSQLDB概述与核心特性 HSQLDB,全称HyperSQL Database,是一款轻量级、开源的纯Java关系型数据库管理系统,以其高性能、高兼容性和易用性而著称。HSQLDB完全由Java语言编写...

    hsqldb相关几个文件

    标题 "hsqldb相关几个文件" 提到的是与HSQldb相关的压缩包资源,HSQldb是一个开源的关系型数据库管理系统,特别适用于Java应用程序。描述中提及的有两个zip文件:hsqldb_1_8_0_10.zip 和 hsqldb-mini.zip,以及一个...

Global site tag (gtag.js) - Google Analytics