`

HSQLDB

    博客分类:
  • DB
阅读更多

HSQLDB

 

前几天做个一个演示的程序,为了方便移植,选择使用 HSQL 作为数据库。HSQL使用 java 语言编写的免费数据库,相对其他数据库,体积很小,是一个非常轻量级的数据库。不需要安装,而且支持嵌套查询和Indentity主键。

下面结合在程序中使用,对 HSQL 作个简要的介绍和使用。

简介

HSQL 主要分为 Server,Standlone,Memory-On ,web服务模式四种方式。

(1) Memory-Only Databases  不做持久化,无密码,不允许远程访问。

url = jdbc:hsqldb:em:dataname  

该模式不保存数据到硬盘上,只是在内存中作数据交换,应用程序退出后则数据被销毁,启动方式:

Connection c = DriverManager.getConnection("jdbc:hsqldb:mem:myDbName", "sa", "")。

(2) Hsqldb Server  支持持久化 ,可以设置密码(设置密码修改test.script文件的user表中的值即可),允许远程访问。  该模式和其他数据库服务器一样,以服务器的形式被启动。

url = jdbc:hsqldb:hsql://server:9001/dataname  

启动方式:

java -cp ../lib/hsqldb.jar org.hsqldb.Server -database.0 mydb -dbname.0 myDbName

(3) In-Process (Standalone) Mode   进程模式支持持久化 ,可将数据存储在本地文件中,可以设置密码(设置密码修改test.script文件的user表中的值即可),不允许远程访问。

该模式因为不用网络连接,在 JVM 中使用,所以可以获得更高的速度。而且不需要用户手工启动数据库。缺点是不可以用DB 工具 察看数据库的当前情况。因此开发时还是推荐使用Server模式。

 In-Process使用的时候不用起服务,直接用JDBC Driver连接URL:

启动方式:

jdbc:hsqldb:file: dataname

 如果db file不在当前目录,可以写为

jdbc:hsqldb:file:path/dataname

(4) Web服务器模式 该模式以WEB服务器的形式启动,并通过HTTP协议接受客户端命令。从1.7.2开始,WEB服务器模式开始支持事务。

java -cp ../lib/hsqldb.jar org.hsqldb.WebServer -database.0 mydb -dbname.0 myDbName

 

使用

(1) 可以到 http://hsqldb.org/ 上下载到其最新的稳定版本。截至笔者写稿的日期,The latest stable version 为 1.8.0.8。

       一个hsqldb.jar文件包括了数据库引擎,数据库驱动,还有其他用户界面操作等内容。

(2) 笔者所使用的是 Memory-Only Databases  用户名为 sa,密码为空。

由于笔者做的是 Web 程序演示,所以可以把数据库引擎和web 容器绑定,在启动Web 服务时启动数据库。

测试是否连接:

Class.forName("org.hsqldb.jdbcDriver");

Connection conn = DriverManager.getConnection("jdbc:hsqldb:mem:.",  "sa", "");

conn.close();

写一个 HSQL 的监听器扩展类。

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.Statement;

import java.util.ResourceBundle;

 

import javax.servlet.ServletContext;

import javax.servlet.ServletContextEvent;

import javax.servlet.ServletContextListener;

 

import org.hsqldb.Server;

 

public class RunHSQLListener implements ServletContextListener {

    private String driver = "";

    private String url = "";

    private String username ="";

    private String password = "";

    private String hsqlUrl = "";

 

    public void contextInitialized(ServletContextEvent event) {

       ServletContext context = event.getServletContext();

       context.log("开始启动HSQL数据库..");

       try {

           ResourceBundle resourceBundle = ResourceBundle

                  .getBundle ("properties.data");

           driver = resourceBundle.getString("driver");

           username = resourceBundle.getString("username");

           password = resourceBundle.getString("password");

           hsqlUrl = resourceBundle.getString("hsqlUrl");

           String databaseName = resourceBundle.getString("databaseName");

           int port = Integer.parseInt (resourceBundle.getString("port"));

           url = hsqlUrl + port + "/" + databaseName;

           Server server = new Server();

           server.setDatabaseName(0, databaseName);

           server.setPort(port);

           server.setSilent(true );

           server.start();

           context.log("成功启动HSQL数据库");

       } catch (Exception ex) {

           System.out .println("启动错误=" + ex);

       }

    }

 

    public void contextDestroyed(ServletContextEvent event) {

       ServletContext context = event.getServletContext();

       Connection conn = null ;

       try {

           Class.forName (driver);

           conn = DriverManager.getConnection (url, username, password);

           Statement stmt = conn.createStatement();

           stmt.executeUpdate("SHUTDOWN;");

           stmt.close ();

       } catch (Exception e) {

       } finally {

           try {

              conn.close();

              context.log("关毕 HSQL 数据库..");

           } catch (Exception e) {

           }

       }

    }

}

同时在web.xml中配置
<listener>
<listener-class>com.iplan.portal.framework.web.HsqlListener</listener-class>
</listener>
这样在启动web容器的时候,同时启动了hsqldb,关闭容器的时候同时也关掉hsqldb。

(3)其它的操作,和一般的JDBC操作相同,将 hsqldb.jar 添加到 classpath 中即可。

 

Hibernage 集成使用

在hibernate.cfg.xml 中

<hibernate-configuration>
    <session-factory>
        <property name="connection.driver_class">org.hsqldb.jdbcDriver</property>
          <property name="connection.url">jdbc:hsqldb:hsql://localhost/mydb</property>
        <property name="connection.username">sa</property>
        <property name="connection.password"></property>
                <property name="dialect">org.hibernate.dialect.HSQLDialect</property>

    </session-factory>
</hibernate-configuration>

也可以将相应值放在属性文件里,在加载到配置文件中。

 

HSQLDB 服务器模式的启动方法

服务器模式的启动方法。假设我们需要创建/启动一个名为mydb的数据库。
操作方法:

(1) 在c:\hsqldb目录下创建mydb目录,用于存放数据。

创建runMydb.bat文件,文件内容为:

java -cp ..\lib\hsqldb.jar org.hsqldb.Server -database mydb

java -cp ../lib/hsqldb.jar org.hsqldb.Server -database.0 mydb -dbname.0 mydb

启动runMydb.bat命令即可
(2) 通过图形界面管理,创建manageMydb.bat文件,内容:

java -cp ..\lib\hsqldb.jar org.hsqldb.util.DatabaseManager -url jdbc:hsqldb:hsql://localhost/mydb

启动manageMydb.bat,即可启动HSQLDB的图形界面管理工具
Hsqldb 的主要工具类:
org.hsqldb.util.DatabaseManager
org.hsqldb.util.DatabaseManagerSwing
org.hsqldb.util.Transfer
org.hsqldb.util.QueryTool
org.hsqldb.util.SqlTool

参考文档 :http://hsqldb.sourceforge.net/web/hsqlDocsFrame.html

分享到:
评论

相关推荐

    hsqldb使用(转载)

    HSQldb是一个轻量级的关系型数据库管理系统,特别适合用于系统演示、开发和测试环境。它的特点是快速、灵活且易于使用。HSQldb支持多种运行模式,满足不同场景的需求。 1. **数据库实例创建** 创建HSQldb数据库...

    HSQLDB中文帮助文档

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

    hsqldb-2.2.8数据库

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

    HSQLDB快速连接数据库

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

    hsqldb的最新版本

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

    hsqldb-2.5.0.jar

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

    hsqldb-lib.zip

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

    hsqldb包和使用说明

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

    hsqldb-2.3.3.zip

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

    hsqldb实例源代码

    HSQldb是一个开源的、轻量级的关系型数据库管理系统,主要设计用于嵌入式环境,同时也支持服务器模式。它实现了SQL标准,支持多种数据库功能,包括事务处理、存储过程、触发器和视图等。本实例源代码将帮助我们深入...

    hsqldb相关几个文件

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

    hsqldb-2.3.2.zip

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

    Hsqldb的缓存分析及调试步骤

    HSQLDB(HyperSQL Database)是一个轻量级、高性能的关系型数据库引擎,常用于Java应用程序和测试环境中。它的缓存机制和数据存储方式对于理解其性能和操作至关重要。以下是对HSQLDB的缓存分析和调试步骤的详细解释...

    开源数据库软件hsqldb

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

    <转>HSQLDB 安装与使用

    HSQLDB,全称 HyperSQL Database,是一款轻量级、高性能、开源的Java关系型数据库管理系统。它在Java环境中运行,适用于开发嵌入式数据库应用、测试环境以及作为服务器模式的数据库系统。HSQLDB因其小巧、快速和易用...

    HSQLDB中文文档 第六章 Text表

    ### HSQLDB中文文档第六章 Text表解析 #### 一、概述 HSQLDB (HyperSQL Database) 是一款高性能的开源轻量级关系型数据库管理系统,适用于开发测试环境及小型应用系统。Text表是HSQLDB的一个特色功能,主要用于...

Global site tag (gtag.js) - Google Analytics