H2是一个用Java开发的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中。
H2最大的用途在于可以同应用程序打包在一起发布,这样可以非常方便地存储少量结构化数据。
它的另一个用途是用于单元测试。启动速度快,而且可以关闭持久化功能,每一个用例执行完随即还原到初始状态。
H2的第三个用处是作为缓存,作为NoSQL的一个补充。当某些场景下数据模型必须为关系型,可以拿它当Memcached使,作为后端MySQL/Oracle的一个缓冲层,缓存一些不经常变化但需要频繁访问的数据,比如字典表、权限表。不过这样系统架构就会比较复杂了。
一、产品优势
·纯Java编写,不受平台的限制;
·只有一个jar文件,适合作为嵌入式数据库使用;
·h2提供了一个十分方便的web控制台用于操作和管理数据库内容;
·功能完整,支持标准SQL和JDBC。麻雀虽小五脏俱全;
·支持内嵌模式、服务器模式和集群。
二、下载和安装
(一)下载
聪明如你肯定会选第二个。Windows、Linux下都可以直接解压缩就用,符合永远中二中年开发者的使用习惯。
(二)解压缩后的目录结构:
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构建脚本
此时就算“安装”完成了。
三、运行模式与运行方式
(一)运行模式
H2有三种运行模式。
1、内嵌模式(Embedded Mode)
内嵌模式下,应用和数据库同在一个JVM中,通过JDBC进行连接。可持久化,但同时只能一个客户端连接。内嵌模式性能会比较好。