HSQL简介

Jun 07, 2016 pm 04:13 PM
dao 前言 我們 測試 簡介

前言 在对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<TextMessageTemplate> tmts = textMessageTemplateDao.selectByBusinessCategory( 203, 0);
        Assert.notNull(tmts);
        Assert.isTrue(tmts.size() == 2);
    }  
}
登入後複製



hyperSqlContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
    xmlns:jdbc="http://www.springframework.org/schema/jdbc"
    xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.s【本文来自鸿网互联 (http://www.68idc.cn)】pringframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.0.xsd">
    <jdbc:embedded-database id="dataSource" type="HSQL">
        <jdbc:script location="classpath:sql/setup.sql" />
        <jdbc:script location="classpath:sql/schema-create.sql" />
        <jdbc:script location="classpath:sql/data-insert.sql" />
    </jdbc:embedded-database>
    <bean id="transactionManager"
        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource" />
    </bean>
    <bean name="baseDao" abstract="true">
        <property name="dataSource" ref="dataSource" />
    </bean>

  <bean name="textMessageTemplateDao" class="com.demandforce.dao.TextMessageTemplateDaoImpl" parent="baseDao" />
</beans>
登入後複製



setup.sql
--
-- MySQL compatibility mode for Hyper SQL

SET 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 (&#39;0&#39;, &#39;203&#39;, &#39;Template1&#39;, null);

INSERT INTO TextMessageTemplate (BusinessID, Type, Template, Industry)
VALUES (&#39;0&#39;, &#39;204&#39;, &#39;Template2&#39;, null);
登入後複製



小结: 虽然HSQLDB有一定的局限性,但是还是不得不说在某些情况下它是一个不错的测试数据库的选择。
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

furmark怎麼看?-furmark怎麼算合格? furmark怎麼看?-furmark怎麼算合格? Mar 19, 2024 am 09:25 AM

furmark怎麼看?-furmark怎麼算合格?

加入全新仙俠冒險! 《誅仙2》「無為測試」預下載開啟 加入全新仙俠冒險! 《誅仙2》「無為測試」預下載開啟 Apr 22, 2024 pm 12:50 PM

加入全新仙俠冒險! 《誅仙2》「無為測試」預下載開啟

Python ORM 效能基準測試:比較不同 ORM 框架 Python ORM 效能基準測試:比較不同 ORM 框架 Mar 18, 2024 am 09:10 AM

Python ORM 效能基準測試:比較不同 ORM 框架

不同語言的函數測試與覆蓋率有什麼不同? 不同語言的函數測試與覆蓋率有什麼不同? Apr 27, 2024 am 11:30 AM

不同語言的函數測試與覆蓋率有什麼不同?

Python ORM 在大數據專案的應用 Python ORM 在大數據專案的應用 Mar 18, 2024 am 09:19 AM

Python ORM 在大數據專案的應用

使用 Python ORM 實現高效的資料持久性 使用 Python ORM 實現高效的資料持久性 Mar 18, 2024 am 09:25 AM

使用 Python ORM 實現高效的資料持久性

CPU-Z怎麼測試CPU效能? CPU-Z測試教程 CPU-Z怎麼測試CPU效能? CPU-Z測試教程 Mar 13, 2024 pm 05:30 PM

CPU-Z怎麼測試CPU效能? CPU-Z測試教程

golang函數閉包在測試中的作用 golang函數閉包在測試中的作用 Apr 24, 2024 am 08:54 AM

golang函數閉包在測試中的作用

See all articles