嵌入式数据库H2

概述

由于项目中需要将数据库嵌入到程序中,一起打包发给客户使用,所以需要使用嵌入式数据库,目前常用的嵌入式数据库有:Berkeley DB、Couchbase Lite、LevelDB、SQLite、UnQLite、H2等,由于H2具有以下特点,所以最终选择了H2作为存储数据库。

1、纯Java编写,不受平台的限制;

2、只有一个jar文件,适合作为嵌入式数据库使用;

3、h2提供了一个十分方便的web控制台用于操作和管理数据库内容;

4、功能完整,支持标准SQL和JDBC。麻雀虽小五脏俱全;

5、支持内嵌模式、服务器模式和集群。

一、H2简介

H2是一个用Java开发的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中。

H2最大的用途在于可以同应用程序打包在一起发布,这样可以非常方便地存储少量结构化数据。
它的另一个用途是用于单元测试。启动速度快,而且可以关闭持久化功能,每一个用例执行完随即还原到初始状态。

H2的第三个用处是作为缓存,作为NoSQL的一个补充。当某些场景下数据模型必须为关系型,可以拿它当Memcached使,作为后端MySQL/Oracle的一个缓冲层,缓存一些不经常变化但需要频繁访问的数据,比如字典表、权限表。不过这样系统架构就会比较复杂了。

二、下载和安装

1、下载

H2数据库下载地址:http://www.h2database.com/html/download.html

嵌入式数据库H2_第1张图片

Windows、Linux下都可以直接解压缩就用。

2、安装

解压缩后的目录结构:

  h2

  |—bin

  | |—h2-1.1.116.jar   //H2数据库的jar包(驱动也在里面)

  | |—h2.bat    //Windows控制台启动脚本

  | |—h2.sh //Linux控制台启动脚本

  | |—h2w.bat //Windows控制台启动脚本(不带黑屏窗口)

  |—docs //H2数据库的帮助文档(内有H2数据库的使用手册)

  |—service //通过wrapper包装成服务。

  |—src //H2数据库的源代码

  |—build.bat //windows构建脚本

  |—build.sh //linux构建脚本

  此时就算“安装”完成了。

三、运行模式与运行方式

1、运行模式

  H2有三种运行模式。

(1)内嵌模式(Embedded Mode)

内嵌模式下,应用和数据库同在一个JVM中,通过JDBC进行连接。 可持久化,但同时只能一个客户端连接。内嵌模式性能会比较好。

(2)服务器模式(Server Mode)

使用服务器模式和内嵌模式一样,只不过它可以跑在另一个进程里。

(3)混合模式

第一个应用以内嵌模式启动它,对于后面的应用来说它是服务器模式跑着的。混合模式是内嵌模式和服务器模式的组合。第一个应用通过内嵌模式与数据库建立连接,同时也作为一个服务器启动,于是另外的应用(运行在不同的进程或是虚拟机上)可以同时访问同样的数据。第一个应用的本地连接与嵌入式模式的连接性能一样的快,而其它连接理论上会略慢。 

2、运行方式

  开发中肯定是Server Mode方便,因为需要用工具管理数据。所以进入H2的bin目录。如下图:

嵌入式数据库H2_第2张图片

如果你在Win环境可以运行h2.bat或h2w.bat。区别只是后者是后台静默运行

嵌入式数据库H2_第3张图片

四、应用程序开发

1、通过远程浏览器来访问h2

访问地址:http://服务器ip:8082/ ,出现如下页面:

嵌入式数据库H2_第4张图片

2、路径的配置

jdbc:h2:~/test是H2的路径。
User name : sa是h2默认的用户,密码可空。最好设置下密码,尤其当你的H2部署在公网时。不然会被无聊人把数据删掉。

3、连接

点击如图Test connect按钮测试连接。此时如果数据库文件本身不存在则会自动创建。点击Connect,进入管理终端。

嵌入式数据库H2_第5张图片

H2的管理终端做得很不错的。按Ctrl+Enter执行输入区的SQL,按Shift+Enter执行当前选中的SQL。

五、应用程序开发

1、加入Maven依赖


com.h2database
h2
1.4.195

2、创建db.properties

driverClassName=org.h2.Driver

此处的写法是使用嵌入模式链接H2库,紧接着那行是使用Server Mode用tcp连接。区别一个是前者性能更好,后者可同时多个客户端连接

url=jdbc:h2:D:/test
#url=jdbc:h2:tcp://1localhost//usr/h2/data/rlib
username=sa
password=

PS:在使用嵌入模式链接H2库时,使用管理页面连接会报错如下:

嵌入式数据库H2_第6张图片

六、H2管理工具-DBeaver

可通过数据库管理工具DBeaver来有效管理H2,直接从网上下载即可,这里不提供下载和安装过程

打开DBeaver.exe,操作如下图:

嵌入式数据库H2_第7张图片

嵌入式数据库H2_第8张图片

嵌入式数据库H2_第9张图片

输入用户名sa

密码自己设置一个 也可以不设,点击下一步

嵌入式数据库H2_第10张图片

嵌入式数据库H2_第11张图片

打开test数据库,即可对表进行增删改查操作了

嵌入式数据库H2_第12张图片

更多博客内容详见我的博客 Wang's Blog

你可能感兴趣的:(JAVA,H2,Database,数据库,DBeaver)