`
dbaspider
  • 浏览: 257088 次
  • 性别: 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安装与使用

    图示和说明详细介绍Hsqldb安装与使用.

    HSQLDB快速上手实录

    不跟你玩了~先介绍一下这个HSQLDB吧,传说是个纯java写的数据库,大名叫HyperSQL DB,不用安装不用部署,核心就一个jar文件,扔到工程里面开个jvm运行一下就行了,完全符合我想要的效果~这是我这两天研究的记录,...

    Eclipse和HSQLDB:将关系数据库服务器嵌入到Eclipse中

    本文介绍如何开发将HSQLDB纯Java关系数据库服务器集成到EclipseWorkbench中的插件。尽管不如DB2功能强大,也不如MySQL流行,但HSQLDB(超音速SQL数据库)可以满足很大范围内Java应用程序的需要,因为它具有可扩展性...

    HsqlDBDriverOOo:LibreOffice OpenOffice的HsqlDB驱动程序

    使用此软件将使您遵守我们的版本介绍: HsqlDBDriverOOo是和/或扩展的一部分,可为您提供这些办公套件中的创新服务。 此扩展允许您直接在Base中使用所选的HsqlDB驱动程序及其所有功能。 它支持由HsqlDB本地管理的...

    HsqlDBembeddedOOo:嵌入式HsqlDB驱动程序

    介绍: HsqlDBembeddedOOo是和/或扩展的一部分,可为您提供这些办公套件中的创新服务。 通过该扩展程序,您可以: 为Linux上的LibreOffice用户克服了。 要在非压缩(拆分)模式下使用嵌入式HsqlDB,使用您选择的...

    数据库操作的单元测试

    1. 测试环境的搭建(DBunit+HSQLDB) 1 1.1. DBunit的简介 1 1.1.1. DBunit简单介绍和原理 1 1.1.2. DBunit的三大核心组件 1 1.1.3. DBunit的安装使用 2 1.2. HSQLDB简介 3 1.2.2. 什么是HSQLDB 3 1.2.3. HSQLDB安装...

    J2EE相关技术介绍

    简单介绍MVC2, IOC, Velocity, Serializable, HSQLDB等相关J2EE技术

    教程:Hibernate,Spring,HSQL,Eclipse和MavenTutorial: Hibernate, Spring, HSQL, Eclipse and Maven

    本书是使用Eclipse逐步介绍Hibernate,Spring,HSQL和Maven的指南,其中包含4个有关流行框架的教程。

    Web应用安全:Sqlmap操作参数介绍.pptx

    完全支持MySQL、Oracle、PostgreSQL、Microsoft SQL Server、Microsoft Access、IBM DB2、SQLite、Firebird、Sybase、SAP MaxDB、HSQLDB和Informix等多种数据库管理系统。 完全支持布尔型盲注、时间型盲注、基于错误...

    Java理论与实践:在没有数据库的情况下进行数据库查询

    本文介绍了开源的内存中的SQL数据库HSQLDB和XQuery。HSQLDB是一个用Java语言编写的可嵌入的数据库引擎。XQuery为生成XML或者HTML文档作为查询结果而设计的,因此不需要对查询结果进行后处理。从开发成本角度看,...

    Java标准版的EJB Persistence(一)

    本文将介绍如何使用它。在本教程里,我们讲到了使用EJB3 persistence——现在也叫做Java Persistence API(JPA)——保持对象的基础知识。我们利用Hibernate的EntityManager/Annotations实现让简单的Person和...

    smtpServerOOo:充当服务器的LibreOffice OpenOffice的smtp客户端

    介绍: smtpServerOOo是和/或扩展的一部分,可为您提供这些办公套件中的创新服务。 此扩展名使您可以通过充当服务器的新smtp客户端在LibreOffice / OpenOffice中发送电子邮件。 作为免费软件,我鼓励您: 复制其...

    gDriveOOo:您的Google云端硬盘数据终于可以在LibreOffice OpenOffice中使用

    介绍: gDriveOOo是和/或扩展的一部分,可为您提供这些办公套件中的创新服务。 使用此扩展程序,即使在脱机状态下,也可以在LibreOffice / OpenOffice中处理手机上的文件(已下载到Android手机的文件)。 作为免费...

    OSGi、Spring、Hibernate集成:动态注册实体类

    平台依赖度低的解决方案 详细介绍见http://blog.csdn.net/flyxxxxx ...其它用到的Bundle包括hibernate、hibernate-annotation、hsqldb、 spring、spring-osgi等。请到http://www.springsource.com/repository/下载。

    api:使用Java和Spring Boot的微服务简介

    此Api使用Java和Spring引导构建,通过简单的DAO和DTO实现向Micoroservices进行介绍。 依存关系 框架:org.springframework.boot 数据存储库:org.springframework.boot \ spring-boot-starter-data-jpa 持久层:org...

    busca-cep:提供REST服务以在内部数据库中搜索邮政编码

    介绍提供REST服务以在内部数据库中搜索邮政编码。 #Technologies这个项目使用带有内存中数据库(hsqldb)的spring-boot,spring-mvc,spring-data,spring-boot-actuator。 #Architecture 3层架构(控制器,服务,...

    moneytransfergateway:用于账户之间转账的Rest API

    这可以通过maven exec命令来完成,我在自述文件的相关部分中详细介绍了启动应用程序的命令。 HSQLDB用于保留数据。 这是一个内存数据库,它在http服务器启动之前启动,并且我加载了一些测试数据来测试api。 启动...

    crud-endereco:REST服务,用于添加,更改,删除和查询用户的地址

    介绍 提供用于注册,更改,删除和查询用户地址的REST服务。 #Technologies这个项目使用带有内存中数据库(hsqldb)的spring-boot,spring-mvc,spring-data,spring-boot-actuator。 #Architecture 3层架构(控制...

    Mybatis分页插件PageHelper的使用详解

    主要介绍了Mybatis分页插件PageHelper的相关资料,该插件目前支持Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库分页需要的朋友可以参考下

Global site tag (gtag.js) - Google Analytics