H2 应用指南
H2 应用指南
概述
H2 是一个开源的嵌入式数据库引擎,采用 java 语言编写,不受平台的限制。同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。
使用说明
H2 控制台应用
H2 允许用户通过浏览器接口方式访问 SQL 数据库。
- 进入官方下载地址,选择合适版本,下载并安装到本地。
- 启动方式:在 bin 目录下,双击 jar 包;执行
java -jar h2*.jar
;执行脚本:h2.bat
或h2.sh
。 - 在浏览器中访问:
http://localhost:8082
,应该可以看到下图中的页面:
data:image/s3,"s3://crabby-images/b67fa/b67fa03e8229e89051c5473a2d0443c705cad700" alt="img"
点击 Connect ,可以进入操作界面:
data:image/s3,"s3://crabby-images/00ee2/00ee2e40b59e94fed79cbf01613b1c0901cd9f39" alt="img"
操作界面十分简单,不一一细说。
嵌入式应用
JDBC API
Connection conn = DriverManager.
getConnection("jdbc:h2:~/test");
conn.close();
连接池
import org.h2.jdbcx.JdbcConnectionPool;
JdbcConnectionPool cp = JdbcConnectionPool.
create("jdbc:h2:~/test", "sa", "sa");
Connection conn = cp.getConnection();
conn.close(); cp.dispose();
Maven
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>1.4.197</version>
</dependency>
详见:Maven 2
Hibernate
hibernate.cfg.xml (or use the HSQLDialect):
<property name="dialect">
org.hibernate.dialect.H2Dialect
</property>
详见:Hibernate
TopLink 和 Glassfish
Datasource class: org.h2.jdbcx.JdbcDataSource
oracle.toplink.essentials.platform.database.H2Platform
运行方式
嵌入式
数据库持久化存储为单个文件。
连接字符串:\~/.h2/DBName
表示数据库文件的存储位置,如果第一次连接则会自动创建数据库。
jdbc:h2:\~/test
- 'test' 在用户根目录下jdbc:h2:/data/test
- 'test' 在 /data 目录下jdbc:h2:test
- 'test' 在当前工作目录
内存式
数据库只在内存中运行,关闭连接后数据库将被清空,适合测试环境
连接字符串:jdbc:h2:mem:DBName;DB_CLOSE_DELAY=-1
如果不指定 DBName,则以私有方式启动,只允许一个连接。
jdbc:h2:mem:test
- 一个进程中有多个连接jdbc:h2:mem:
- 未命名的私有库,一个连接
服务模式
H2 支持三种服务模式:
- web server:此种运行方式支持使用浏览器访问 H2 Console
- TCP server:支持客户端/服务器端的连接方式
- PG server:支持 PostgreSQL 客户端
启动 tcp 服务连接字符串示例:
jdbc:h2:tcp://localhost/\~/test
- 用户根目录jdbc:h2:tcp://localhost//data/test
- 绝对路径
启动服务
执行 java -cp *.jar org.h2.tools.Server
执行如下命令,获取选项列表及默认值
java -cp h2*.jar org.h2.tools.Server -?
常见的选项如下:
- -web:启动支持 H2 Console 的服务
- -webPort
<port>
:服务启动端口,默认为 8082 - -browser:启动 H2 Console web 管理页面
- -tcp:使用 TCP server 模式启动
- -pg:使用 PG server 模式启动
设置
jdbc:h2:..;MODE=MySQL
兼容模式(或 HSQLDB 等)jdbc:h2:..;TRACE_LEVEL_FILE=3
记录到*.trace.db
连接字符串参数
DB_CLOSE_DELAY
- 要求最后一个正在连接的连接断开后,不要关闭数据库MODE=MySQL
- 兼容模式,H2 兼容多种数据库,该值可以为:DB2、Derby、HSQLDB、MSSQLServer、MySQL、Oracle、PostgreSQLAUTO_RECONNECT=TRUE
- 连接丢失后自动重新连接AUTO_SERVER=TRUE
- 启动自动混合模式,允许开启多个连接,该参数不支持在内存中运行模式TRACE_LEVEL_SYSTEM_OUT
、TRACE_LEVEL_FILE
- 输出跟踪日志到控制台或文件, 取值 0 为 OFF,1 为 ERROR(默认值),2 为 INFO,3 为 DEBUGSET TRACE_MAX_FILE_SIZE mb
- 设置跟踪日志文件的大小,默认为 16M
maven 方式
此外,使用 maven 也可以启动 H2 服务。添加以下插件
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<goal>java</goal>
</goals>
</execution>
</executions>
<configuration>
<mainClass>org.h2.tools.Server</mainClass>
<arguments>
<argument>-web</argument>
<argument>-webPort</argument>
<argument>8090</argument>
<argument>-browser</argument>
</arguments>
</configuration>
</plugin>
在命令行中执行如下命令启动 H2 Console
mvn exec:java
或者建立一个 bat 文件
@echo off
call mvn exec:java
pause
此操作相当于执行了如下命令:
java -jar h2-1.3.168.jar -web -webPort 8090 -browser
Spring 整合 H2
(1)添加依赖
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>1.4.194</version>
</dependency>
(2)spring 配置
<?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:jdbc="http://www.springframework.org/schema/jdbc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
http://www.springframework.org/schema/jdbc
http://www.springframework.org/schema/jdbc/spring-jdbc.xsd">
<!--配置数据源-->
<bean id="dataSource" class="org.h2.jdbcx.JdbcConnectionPool"
destroy-method="dispose">
<constructor-arg>
<bean class="org.h2.jdbcx.JdbcDataSource">
<!-- 内存模式 -->
<property name="URL" value="jdbc:h2:mem:test"/>
<!-- 文件模式 -->
<!-- <property name="URL" value="jdbc:h2:testRestDB" /> -->
<property name="user" value="root"/>
<property name="password" value="root"/>
</bean>
</constructor-arg>
</bean>
<!-- JDBC模板 -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<constructor-arg ref="dataSource"/>
</bean>
<bean id="myJdbcTemplate" class="org.zp.notes.spring.jdbc.MyJdbcTemplate">
<property name="jdbcTemplate" ref="jdbcTemplate"/>
</bean>
<!-- 初始化数据表结构 -->
<jdbc:initialize-database data-source="dataSource" ignore-failures="ALL">
<jdbc:script location="classpath:sql/h2/create_table_student.sql"/>
</jdbc:initialize-database>
</beans>
H2 SQL
SELECT
data:image/s3,"s3://crabby-images/db1ef/db1ef4fd1895154b384eb6887251bf711565afc3" alt="img"
INSERT
data:image/s3,"s3://crabby-images/13479/1347900b14dd0ea31e4ea2be0633ab04b1d76862" alt="img"
UPDATE
data:image/s3,"s3://crabby-images/c2d53/c2d5353e8c6863f85f7e3ca3f7c2195d06e30a44" alt="img"
DELETE
data:image/s3,"s3://crabby-images/07ffd/07ffd9d542dd14465bf6aaaaca895c72af455a63" alt="img"
BACKUP
data:image/s3,"s3://crabby-images/d6635/d6635dfd88b99bded06121364f60b3b09999e4f0" alt="img"
EXPLAIN
data:image/s3,"s3://crabby-images/4d257/4d257421cb48118b318587483268f5351ddfa33c" alt="img"
7、MERGE
RUNSCRIPT
运行 sql 脚本文件
data:image/s3,"s3://crabby-images/d015c/d015c2f7a5fb08d8d4e0c607d025b7eb531952c9" alt="img"
SCRIPT
根据数据库创建 sql 脚本
data:image/s3,"s3://crabby-images/8b12f/8b12f224abde4fb3d1df8d5e274297f97c5e8c8f" alt="img"
SHOW
data:image/s3,"s3://crabby-images/4f966/4f9664c6abe68452535cd5733c170e4b3359803d" alt="img"
ALTER
ALTER INDEX RENAME
data:image/s3,"s3://crabby-images/c185d/c185d3c706b5c13c4d145aca4292fb2ac114e729" alt="img"
ALTER SCHEMA RENAME
data:image/s3,"s3://crabby-images/50ac0/50ac02f2bce91d2d4c16b0830a8676f40885ddc3" alt="img"
ALTER SEQUENCE
data:image/s3,"s3://crabby-images/4bbba/4bbbac1fb1accfec2db4fab1e29e678a139f20c9" alt="img"
ALTER TABLE
data:image/s3,"s3://crabby-images/453fe/453fe5aefbc284054fbb504406131fd508570ed2" alt="img"
增加约束
data:image/s3,"s3://crabby-images/62650/626500b9d1cf58a2390e2f6cca1cc7ffb426e44a" alt="img"
修改列
data:image/s3,"s3://crabby-images/ece87/ece87d916dd508a66dc134c7a67c9c157bae0703" alt="img"
删除列
data:image/s3,"s3://crabby-images/aaa95/aaa95be32e7f75f8098272b6a81e44dd12f3cbb7" alt="img"
删除序列
data:image/s3,"s3://crabby-images/579c7/579c7997c2a43b6c1a2b6afd45e875cf9b995b58" alt="img"
ALTER USER
修改用户名
data:image/s3,"s3://crabby-images/d5bd0/d5bd0daaee9252e920fcd0ccd2a6ef17f04de381" alt="img"
修改用户密码
data:image/s3,"s3://crabby-images/04dbc/04dbced363ac8691d2e3a313d68db2605227ae33" alt="img"
ALTER VIEW
data:image/s3,"s3://crabby-images/66fbd/66fbdf3a3d0444881032161bd48e190bdae731c4" alt="img"
COMMENT
data:image/s3,"s3://crabby-images/2b2af/2b2afb3d748d0666fde001967ccfaf56a5dbdc46" alt="img"
CREATE CONSTANT
data:image/s3,"s3://crabby-images/065af/065afd7d3c60ab83cfca1236918d61744e38f0db" alt="img"
CREATE INDEX
data:image/s3,"s3://crabby-images/e5e98/e5e984b22419969088c01d45f818a7df0032206c" alt="img"
CREATE ROLE
data:image/s3,"s3://crabby-images/011d4/011d4ad3543f153e360d6a79f36369fdd8772e55" alt="img"
CREATE SCHEMA
data:image/s3,"s3://crabby-images/d4412/d441256fbecd3c4d5efc30949df951b4c48cea7d" alt="img"
CREATE SEQUENCE
data:image/s3,"s3://crabby-images/5b06f/5b06f9aff13e58ccb0c44fc832e6e26aee8b9149" alt="img"
CREATE TABLE
data:image/s3,"s3://crabby-images/b2692/b26921e1d96103a6000cc7a4e596912484c639c6" alt="img"
CREATE TRIGGER
data:image/s3,"s3://crabby-images/66ac9/66ac9fa02d8254a16e1974820d820fbcc5bf29ea" alt="img"
CREATE USER
data:image/s3,"s3://crabby-images/ecc10/ecc10a31c1c9c2c154c2f2290ffeb437bfb0087f" alt="img"
CREATE VIEW
data:image/s3,"s3://crabby-images/9a0f8/9a0f83b2fa4e39ac8489fe7fdf8a26252d6335aa" alt="img"
DROP
data:image/s3,"s3://crabby-images/9281c/9281c423f38aa4e81f4dce173e33a9dc361ea210" alt="img"
GRANT RIGHT
给 schema 授权授权
data:image/s3,"s3://crabby-images/9e21c/9e21c55bb378bd05b35e8d88ab48f149e6deca83" alt="img"
给 schema 授权给 schema 授权
data:image/s3,"s3://crabby-images/ddc9d/ddc9d97551c5efa00838215e64a2a00d1f04690f" alt="img"
复制角色的权限
data:image/s3,"s3://crabby-images/dc611/dc61145888372bb2f9cb8cabca7166021e87ce11" alt="img"
REVOKE RIGHT
移除授权
data:image/s3,"s3://crabby-images/8e99d/8e99d00c9507adff717c29e8dadfddf0cd701441" alt="img"
移除角色具有的权限
data:image/s3,"s3://crabby-images/04178/041781df3e785adae7e873ddeba5a0537a86e185" alt="img"
ROLLBACK
从某个还原点(savepoint)回滚
data:image/s3,"s3://crabby-images/4b344/4b3445655271c79ba93e3d6fd0b9057d1495b355" alt="img"
回滚事务
data:image/s3,"s3://crabby-images/4941c/4941c5f16771395ed8c78b65932d6040d2e15fa6" alt="img"
创建 savepoint
data:image/s3,"s3://crabby-images/a82c4/a82c4bf2c6974dccd7ff84bb1c1356dbf0f7f4c2" alt="img"
数据类型
data:image/s3,"s3://crabby-images/5793c/5793c9005a373a7b52994575322e64a8bf46e6b7" alt="img"
INT Type
data:image/s3,"s3://crabby-images/f970c/f970c04f85592e97fc57962bc748863168b22405" alt="img"
集群
H2 支持两台服务器运行两个数据库成为集群,两个数据库互为备份,如果一个服务器失效,另一个服务器仍然可以工作。另外只有服务模式支持集群配置。
H2 可以通过 CreateCluster 工具创建集群,示例步骤如下(在在一台服务器上模拟两个数据库组成集群):
- 创建目录
- 创建两个服务器工作的目录
- 启动 tcp 服务
- 执行如下命令分别在 9101、9102 端口启动两个使用 tcp 服务模式的数据库
- 使用 CreateCluster 工具创建集群
- 如果两个数据库不存在,该命令将会自动创建数据库。如果一个数据库失效,可以先删除坏的数据库文件,重新启动数据库,然后重新运行 CreateCluster 工具
- 连接数据库现在可以使用如下连接字符串连接集群数据库
- 监控集群运行状态
- 可以使用如下命令查看配置的集群服务器是否都在运行
- 限制
- H2 的集群并不支持针对事务的负载均衡,所以很多操作会使两个数据库产生不一致的结果
- 执行如下操作时请小心:
- 自动增长列和标识列不支持集群,当插入数据时,序列值需要手动创建不支持 SET AUTOCOMMIT FALSE 语句;
- 如果需要设置成为不自动提交,可以执行方法 Connection.setAutoCommit(false)
参考资料
🚪 传送
◾ 💧 钝悟的 IT 知识图谱 ◾