HSQLDB 介绍

2023-10-28

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
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

HSQLDB 介绍 的相关文章

随机推荐

  • 如何用清华 ChatGLM 微调一个私域大模型

    曹政 曹大是我们圈子里公认的大佬 他在技术上不仅早早领先 在思维认知领域更是帮助很多小伙伴快速成长 没有 ChatGPT 之前 我一直在想 能否将曹大的思维 直接植入过来 就跟无崖子传输功力 头碰头就行 当然我多想了 ChatGPT 出来后
  • EXT.JS2.2表单上传文件

    var uploadFile new Ext form TextField fieldLabel 上传文件 id file name uploadFile height 25 width 860 blankText 请上传文件 itemCl
  • React中怎么实现状态自动保存(KeepAlive)?

    什么是状态保存 移动端中 用户访问了一个列表页 上拉浏览列表页的过程中 随着滚动高度逐渐增加 数据也将采用触底分页加载的形式逐步增加 列表页浏览到某个位置 用户看到了感兴趣的项目 点击查看其详情 进入详情页 从详情页退回列表页时 需要停留在
  • 关于STM32 定时器PWM输出,关闭PWM时,输出引脚电平控制。

    STM32的定时很多 功能也比较全面 pwm功能更是比较常用的功能 特别是对直流电机调速使用 但是有时我们停止PWM的时候希望 PWM的输出通道输出固定电平 下面我说一下其中的一种实现方法 根据数据手册得知 只要将OC1M设置为 100或者
  • 鞋子AJ,表格AG,ag-grid社区版排序错误问题

    ag grid表格数字格式排序是按照1 10 11 2 3 4这样排序的 相信很多小伙伴都知道怎么解决 只需要在sort方法内arr sort function a b return a b 就可以 我之前在源码里找到了这个 但是没法解决
  • 李峋同款爱心Python代码版来了

    最近看到不少关于李峋同款爱心的视频 文章 今天我们也分享一下李峋同款爱心 Python 代码版 简单来说李峋同款爱心就是一个动态的 型效果 主要 Python 代码实现如下 def init self generate frame 20 原
  • Python自动化测试的配置层实现方式对标与落地

    Python中什么是配置文件 配置文件如何使用 有哪些支持的配置文件等内容 话不多说 让我们一起看看吧 1 什么是配置文件 配置文件是用于配置计算机程序的参数和初始化设置的文件 如果没有这些配置程序可能无法运行或是影响运行 运行速度 便捷性
  • C# 使用SqlDataReader读取数据库数据

    本文主要讲述如何使用SqlDataReader方法来读取数据 来完成数据库增删改查中查的工作 这是C 读取数据库的主要方法 一 环境介绍 Visual Studio 2015 SQL Server 2012 控制台应用程序 使用的数据库名称
  • 在Gitee搭建属于自己的博客

    搭建属于自己的私人博客 工具安装 1 安装 git git 版本控制工具 链接 https pan baidu com s 19V8BH4kO9h6eVNFhMzAU4w 提取码 chgo 1 1 选择 next 1 2 选择安装路径 1
  • 全球十大即时通信软件最新排名

    第十名 Signal 1亿用户 Signal是一款提供加密通信的即时通讯软件 用户可以进行点对点的私密聊天和通话 优势 客户端及服务器开源 默认私聊 群聊端对端加密 纯净无广告 没有复杂功能 局限 注册使用Signal必须与手机捆绑 无法在
  • SQL数据库编写及示例

    一 数据库编写 1 数据库常用约束 主键约束 primary key 外键约束 foreign key references 唯一值约束 unique 默认值约束 default 检查约束 check 非空约束 not null 标识列 i
  • Apolo学习

    安装 java1 8 mysql 5 6 5以上 下载quickStart的包 早apollo下执行两个sql 如果不执行这两个sql apollo是执行不起来的 会有两个表来记录apollo的执行情况 其中一个表叫apolloportal
  • Sass语法(三)之循环

    一 数据类型 1 数字 如 1 2 13 10px 2 字符串 有俩种类型 a 有引号字符串 quoted strings 如 Lucida Grande http sass lang com b 无引号字符串 unquoted strin
  • C语言--指针:最底层的解释(慢慢懂~)

    指针 又可以叫它为地址 他表示的就是变量的被存储的地址 举个例子 创建整型变量a 于是a被存储到了内存中 我们就可以通过创建指针来找到他被存储到了哪个位置 取地址操作符 我们可以打印出a的指针 在这里 p为指针变量 指向a 不同于指针 打印
  • C++STL之vector与list

    文章目录 关于vector的用法 关于List的用法 vector和list的区别 关于vector的用法 include
  • C++ 享元模式

    什么是享元模式 享元模式是一种结构型设计模式 实现了在较少内存开销的同时 又支持了大量的对象 主要在资源有限的情况下 对创建大量对象行为的一种约束行为 享元模式的适用特征 当程序中有大量的相同对象 这些对象消耗了大量的内存 这些对象的状态可
  • centos7系统引导自动重启_Linux老鸟给出的Linux系统故障问题汇总,值得永久收藏...

    一 处理linux系统故障的思路 作为一名优秀的linux运维工程师 一定要有一套清晰 明确的解决故障思路 当问题出现时 才能迅速定位 解决问题 在开始本文学习之前 我根据多年工作和处理问题和故障的经验 总结出了一套处理问题的一般思路 供大
  • 全卷积网络FCN详细讲解(超级详细哦)

    原文链接 https blog csdn net qq 41760767 article details 97521397 depth 1 utm source distribute pc relevant none task utm so
  • Job thrrew an unhandled exception 是什么报错

    Job threw an unhandled exception 是一个通用的错误信息 它表明在执行一个作业 Job 时发生了未处理的异常 这个错误信息并不提供具体的异常信息 而只是告诉你作业执行过程中出现了未处理的异常 并且该异常没有被适
  • HSQLDB 介绍

    HSQLDB HSQL使用 java 语言编写的免费数据库 相对其他数据库 体积很小 是一个非常轻量级的数据库 不需要安装 而且支持嵌套查询和Indentity主键 下面结合在程序中使用 对 HSQL 作个简要的介绍和使用 一 简介 HSQ