专业IT网络知识平台,分享IT百科知识、生活百科知识解答!

易企推科技
易企推科技

HSQL简介

来源:小易整编  作者:小易  发布时间:2024-03-13 08:23
摘要:前言在对dao层写测试类的时候,我们需要一个测试数据库,一般我们会是专门建立一个真实的测试数据库,但是有了HSQLDB事情就变得简单了起来。正题一、简介:hsql数据库是一款纯Java编写的免费数据库,许可是BSD-style的协议...

前言 在对dao层写测试类的时候,我们需要一个测试数据库,一般我们会是专门建立一个真实的测试数据库,但是有了HSQLDB事情就变得简单了起来。 正题 一、简介: hsql数据库是一款纯Java编写的免费数据库,许可是BSD-style的协议,如果你是使用Java编程的话,

前言 在对dao层写测试类的时候,我们需要一个测试数据库,一般我们会是专门建立一个真实的测试数据库,但是有了HSQLDB事情就变得简单了起来。正题 一、简介: hsql数据库是一款纯Java编写的免费数据库,许可是BSD-style的协议,如果你是使用Java编程的话,不妨考虑一下使用它,相对其他数据库来说,其体积小,才563kb。仅一个hsqldb.jar文件就包括了数据库引擎,数据库驱动,还有其他用户界面操作等内容。在Java开源世界里,hsql是极为受欢迎的(就Java本身来说),JBoss应用程序服务器默认也提供了这个数据库引擎。由于其体积小的原因,又是纯Java设计,又支持SQL99,SQL2003大部分的标准,所以也是作为商业应用程序展示的一种选择。二、优点1.轻巧,只有600多K,运行速度非常快。结合Hibernate数据库无关的特性,非常适合在项目开发的时候使用。2.作为单元测试数据库。单元测试的时候,启动HSQLDB的file模式,数据不存盘,可以保证测试原子性。3.来回复制,随身携带。4.不需要安装,使用非常方便。5.稳定,而且支持的数据量足够大。6.小型项目作为现场数据库使用,不需要安装Oracle之类的大型DB,减轻了维护成本,并且,HSQLDB非常容易备份。三、局限性1.HSQLDB并不是一个正式的数据库产品,如果用来做为商业应用数据库或者说开发时的数据库,不太妥当。这点在HSQLDB的官方文档里也提到了。2.作为测试数据库来讲,由于HSQLDB支持标准SQL, 所以一般情况没问题,但是对于某个数据(如MySql)的特殊语法则不兼容,容易报错。四、作为测试数据库的使用 作为测试数据库的话,主要用于测试与数据有交互的类,即我们平时所讲的dao层。 HSQLDB使用很简单,只需要从官网下载最新版本的zip包然后解压放到lib目录下即可(当然maven项目需要添加到pom.xml中进行引用),然后需要一个配置文件 两个sql文件和一个测试类即可。测试类:
package com.demandforce.dao;import java.util.Collection;import org.junit.Test;import org.junit.runner.RunWith;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.test.context.ContextConfiguration;import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;import org.springframework.util.Assert;import com.demandforce.model.TextMessageTemplate;@RunWith(SpringJUnit4ClassRunner.class)@ContextConfiguration(locations = {"classpath:context/hyperSqlContext.xml"})public class TextMessageTemplateRetrievalTest {    @Autowired    private TextMessageTemplateDao textMessageTemplateDao;                @Test    public void testSelectByBusinessCategory() {        Collection tmts = textMessageTemplateDao.selectByBusinessCategory( 203, 0);        Assert.notNull(tmts);        Assert.isTrue(tmts.size() == 2);    }  }
登录后复制hyperSqlContext.xml
                                                                  
登录后复制setup.sql
---- MySQL compatibility mode for Hyper SQLSET DATABASE SQL SYNTAX MYS TRUE;
登录后复制schema-create.sql
DROP TABLE IF EXISTS TextMessageTemplate;CREATE TABLE TextMessageTemplate (  ID INT NOT NULL AUTO_INCREMENT,  BusinessID INT NOT NULL,  Type INT NOT NULL,  Template varchar(1000),  CreatedDate datetime DEFAULT NULL,  LastModifiedDate timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,  CreatedUserId INT DEFAULT 0,  LastModifiedUserId INT DEFAULT 0,  Delivery INT DEFAULT 0,  DeliveryWindow INT DEFAULT 1,  BusinessCalendar INT NOT NULL DEFAULT 0,  DeliveryTime datetime DEFAULT NULL,  CardCount INT DEFAULT 0,  Segment INT DEFAULT 0,  FrontImage varchar(255) DEFAULT NULL,  IncludeItems INT DEFAULT 1,  IncludeReview INT DEFAULT 1,  IncludeCoupon INT DEFAULT 1,  services varchar(5000) DEFAULT NULL,  Industry INT DEFAULT NULL,  PRIMARY KEY (ID));
登录后复制data-insert.sql
INSERT INTO TextMessageTemplate (BusinessID, Type, Template, Industry) VALUES ('0', '203', 'Template1', null);INSERT INTO TextMessageTemplate (BusinessID, Type, Template, Industry)VALUES ('0', '204', 'Template2', null);
登录后复制小结: 虽然HSQLDB有一定的局限性,但是还是不得不说在某些情况下它是一个不错的测试数据库的选择。

HSQL简介


本文地址:网络知识频道 https://www.hkm168.com/jiqiao/1147185.html,易企推百科一个免费的知识分享平台,本站部分文章来网络分享,本着互联网分享的精神,如有涉及到您的权益,请联系我们删除,谢谢!


网络知识
小编:小易整编
相关文章相关阅读
  • 奇异值分解(SVD)简介及其在图片压缩中的示例

    奇异值分解(SVD)简介及其在图片压缩中的示例

    奇异值分解(SVD)是一种用于矩阵分解的方法。它将一个矩阵分解为三个矩阵的乘积,分别是左奇异向量矩阵、右奇异向量矩阵和奇异值矩阵。SVD在数据降维、信号处理、推荐系统等领域广泛应用。通过SVD,我们可以将高维数据降低到低维空间,从而提取出数...

  • Python中的lstrip()方法使用简介

    Python中的lstrip()方法使用简介

     lstrip()方法返回所有字符被去除开头字符串(缺省为空格字符)的一个复本。语法以下是lstrip()方法的语法:str.lstrip([chars])登录后复制参数chars--您提供要剪裁的字符。返回值此方法返回所有...

  • OrientDB简介

    OrientDB简介

    OrientDB是一个开源的NoSQL数据库管理系统。NoSQL数据库提供了一种机制,用于存储和检索引用非表格数据(如文档数据或图形数据)之外的数据的非关系或非关系数据。大数据和实时Web应用程序越来越多地使用NoSQL数据库。NoS...

  • Anime.js 简介

    Anime.js 简介

    Anime.js是一个轻量级JavaScript库,具有简单、有效的API。它可与JavaScript对象、CSS和DOM元素配合使用,而且Anime.js也易于使用。传统上,我们通过逐渐修改元素的样式来制作动画。这样...

  • Anime.js 简介

    Anime.js 简介

    Anime.js是一个轻量级JavaScript库,具有简单、有效的API。它可与JavaScript对象、CSS和DOM元素配合使用,而且Anime.js也易于使用。传统上,我们通过逐渐修改元素的样式来制作动画。这样...

  • Python中的Psycopg2模块简介

    Python中的Psycopg2模块简介

    WeknowthatPythonisaprogramminglanguageusedforaccomplishingvarioustasksinfieldssuchasDataAnalysis,AI,...

  • 什么是DOM对象?DOM对象简介

    什么是DOM对象?DOM对象简介

    本篇文章给大家带来的内容是关于什么事dom对象?dom对象简介,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。一、DOM对象DOM,全称“DocumentObjectModel(文档对象模型)”,它是由W3C组织定义的一...

  • HSQL简介

    HSQL简介

    前言在对dao层写测试类的时候,我们需要一个测试数据库,一般我们会是专门建立一个真实的测试数据库,但是有了HSQLDB事情就变得简单了起来。正题一、简介:hsql数据库是一款纯Java编写的免费数据库,许可是BSD-style的协议...

  • 周排行
  • 月排行
  • 年排行

精彩推荐