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

HSQLDB 介绍

阅读更多

HSQLDB


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快速连接数据库

    1. **运行与使用HSQLDB**:介绍了HSQLDB的基本使用方法,包括如何运行HSQLDB及其提供的不同工具(如`HsqldbServer`、`HsqldbWebServer`等),以及如何在不同模式下使用HSQLDB。 2. **SQL问题**:探讨了HSQLDB对SQL...

    hsqldb的最新版本

    7. **文档更新**:与新版本一同发布的可能还有更新后的用户手册和开发者指南,这些文档会详细介绍新特性和使用方法,帮助开发者更好地理解和使用HSQldb。 8. **社区支持**:HSQldb的社区活跃度是其持续发展的关键,...

    HSQLDB中文帮助文档

    - **数据库连接**:介绍了如何使用JDBC连接HSQLDB。 - **属性文件**:详细说明了如何配置Server和WebServer的属性。 - **个别数据库属性**:针对每个数据库实例可以配置的属性,如缓存大小等。 #### 七、部署问题 -...

    HSQLDB中文手册

    - **约束和索引**:详细介绍了主键、唯一性约束、外键以及索引的作用与实现方法,帮助提高数据一致性和查询性能。 - **数据类型与算术操作**:涵盖整型、浮点型、日期时间、字符串等多种数据类型,以及算术运算规则...

    hqldb数据库在java程序中以内存方式启动

    1. **HSQLDB介绍**:HSQLDB是一个纯Java实现的关系数据库管理系统,支持SQL标准,包括SQL:2016。它提供了单用户和多用户模式,可以在内存中运行,也可以存储在文件系统中。 2. **内存模式启动**:在Java程序中,...

    HSQLDB_guide

    这两本书籍详尽地介绍了HSQLDB的安装、配置、使用方法以及高级特性,包括数据库创建、表操作、查询语言、事务处理、备份与恢复等内容,是学习和掌握HSQLDB的重要资料。 通过阅读这两份指南,你可以了解到如何创建...

    SQL.zip_C5UR_eclipse sql_previouss87

    1. **HSQLDB介绍**:HSQLDB是一个开源的、轻量级的关系数据库管理系统,完全用Java编写,适用于内存和磁盘存储模式。它支持ACID事务,SQL:2003标准,以及JDBC和JPA接口。 2. **Eclipse IDE与数据库集成**:Eclipse...

    HSQLDB用户手册

    - **数据类型简介**:简要介绍了HSQLDB支持的主要数据类型及其用途。 - **数值类型**:包括整型、浮点型等,适用于存储数字数据。 - **布尔类型**:表示逻辑值TRUE或FALSE。 - **字符字符串类型**:用于存储文本...

    hsqldb-2.5.0.zip

    下面将对HSQDDL的核心特性、使用方法以及在Java开发中的应用进行详细介绍。 一、HSQDDL的核心特性 1. **内存模式与文件模式**:HSQDDL支持两种运行模式,一是内存模式,数据存储在内存中,速度极快,但关闭数据库...

    HSQLDB 中文文档

    从给定的文件信息中,我们可以提取出关于HSQLDB的多个重要知识点,这些知识点涵盖了HSQLDB的基本介绍、运行模式、SQL支持、高级话题以及部署和管理等关键领域。 ### HSQLDB —— 轻量级纯Java关系型数据库 HSQLDB...

    junit-test-dao

    HSQLDB介绍** - **概述**:HSQLDB是一款轻量级的纯Java数据库,非常适合用于单元测试场景,因为它可以在内存中运行,无需额外安装配置。 - **优点**:易于集成、速度快、占用资源少。 **2. JUnit4** - **概述**...

    Hsqldb1.8.0版

    在压缩包中的`HSQLDB_guide_zh.pdf`是HSQDB的中文用户指南,这份文档详细介绍了如何安装、配置和使用HSQDB,包括创建数据库、编写SQL语句、管理用户和权限等。通过阅读这份文档,用户可以快速掌握HSQDB的基本操作,...

    HSQLDB用户指导学习手册

    - **运行工具**:介绍了运行HSQLDB所需的工具和环境配置,确保用户能够顺利启动和使用数据库。 - **服务器模式**:涵盖了HSQLDB支持的各种服务器模式,包括HSQLDB Server、HSQLDB Web Server、HSQLDB Servlet以及In-...

    Back_HSqlDB:java 内置数据库

    1. **HSQLDB介绍:** HSQLDB是一个开源、免费的关系型数据库,支持标准的SQL语法,包括SQL-92和SQL:2003。它提供两种模式,一种是内存模式,数据存储在内存中,适用于临时数据存储或测试;另一种是文件模式,数据...

    跟我StepByStep学FLEX教程------王一松

    - **hsqldb介绍**:hsqldb是一个轻量级的关系型数据库管理系统。 - **连接配置**:学习如何配置Flex应用与hsqldb的连接。 #### 29. Demo13:Flex访问数据库 - **数据库连接**:介绍如何建立Flex应用与数据库之间的...

Global site tag (gtag.js) - Google Analytics