H2是一个开源的嵌入式数据库引擎,采用java语言编写,不受平台的限制,同时H2提供了一个十分方便的web控制台用于操作和管理数据库内容。H2还提供兼容模式,可以兼容一些主流的数据库,因此采用H2作为开发期的数据库非常方便。
一、引入Maven依赖
在maven中定义H2数据库的版本属性
<properties> <h2.version>1.3.172</h2.version> </properties>ataNode对象 } |
添加H2依赖
<dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <version>${h2.version}</version> <scope>test</scope> </dependency> |
二、运行方式
1、在内存中运行
数据库只在内存中运行,关闭连接后数据库将被清空,适合测试环境
连接字符串:
jdbc:h2:mem:DBName;DB_CLOSE_DELAY=-1 |
如果不指定DBName,则以私有方式启动,只允许一个连接
2、嵌入式
数据库持久化存储为单个文件
连接字符串:
jdbc:h2:file:~/.h2/DBName;AUTO_SERVER=TRUE |
~/.h2/DBName表示数据库文件的存储位置,如果第一次连接则会自动创建数据库
3、服务模式
H2支持三种服务模式:
1.web server:此种运行方式支持使用浏览器访问H2 Console
2.TCP server:支持客户端/服务器端的连接方式
3.PG server:支持PostgreSQL客户端
启动tcp服务连接字符串示例:
jdbc:h2:tcp://localhost/~/test 使用用户主目录
jdbc:h2:tcp://localhost//data/test 使用绝对路径
4、连接字符串参数
1.DB_CLOSE_DELAY:要求最后一个正在连接的连接断开后,不要关闭数据库
2.MODE=MySQL:兼容模式,H2兼容多种数据库,该值可以为:DB2、Derby、HSQLDB、MSSQLServer、MySQL、Oracle、PostgreSQL
3.AUTO_RECONNECT=TRUE:连接丢失后自动重新连接
4.AUTO_SERVER=TRUE:启动自动混合模式,允许开启多个连接,该参数不支持在内存中运行模式
5.TRACE_LEVEL_SYSTEM_OUT、TRACE_LEVEL_FILE:输出跟踪日志到控制台或文件,
取值0为OFF,1为ERROR(默认值),2为INFO,3为DEBUG
6.SET TRACE_MAX_FILE_SIZE mb:设置跟踪日志文件的大小,默认为16M
5、启动服务模式,打开H2 Console web页面
启动服务,在命令行中执行
java -cp h2*.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模式启动
此外,使用maven也可以启动H2服务
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>1.0.0</modelVersion> <version>1.0.0</version> <groupId>groupid</groupId> <artifactId>h2-console</artifactId> <name>H2 Console</name> <packaging>pom</packaging> <properties> <h2.version>1.3.172</h2.version> </properties> <dependencies> <dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <version>${h2.version}</version> <scope>runtime</scope> </dependency> </dependencies> <build> <plugins> <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> </plugins> </build> </project> |
在命令行中执行如下命令启动H2 Console
或者建立一个bat文件
@echo off call mvn exec:java pause |
此操作相当于执行了如下命令:
java -jar h2-1.3.168.jar -web -webPort 8090 -browser |
三、应用程序配置
1、Properties配置
java应用程序关于数据库的Properties配置文件示例如下:
#h2 database settings jdbc.driver=org.h2.Driver jdbc.url=jdbc:h2:file:~/.h2/quickstart;AUTO_SERVER=TRUE;DB_CLOSE_DELAY=-1 jdbc.username=sa jdbc.password=
#connection pool settings
jdbc.pool.maxIdle=5
jdbc.pool.maxActive=40 |
2、初始化数据库
(1)、在Maven中初始化数据库
可以创建一个Profile,专门用于初始化数据库。在maven中可以通过maven-antrun-plugin执行ant任务,在ant任务中使用sql标签可以执行sql脚本文件,配置示例如下:
<profile> <id>refresh-db</id> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-antrun-plugin</artifactId> <configuration> <target> <property file="src/main/resources/application.properties" /> <sql driver="${jdbc.driver}" url="${jdbc.url}" userid="${jdbc.username}"
password="${jdbc.password}" onerror="continue" encoding="${project.build.sourceEncoding}"> <classpath refid="maven.test.classpath" /> <transaction src="src/main/resources/sql/h2/schema.sql"/> <transaction src="src/test/resources/data/h2/import-data.sql"/> </sql> </target> </configuration> </plugin> </plugins> </build> </profile> |
执行如下命令调用该Profile,初始化数据库
mvn antrun:run -Prefresh-db |
(2)、在Spring中初始化数据库
Spring Profile和maven profile一样,也可以模拟不同的开发环境。在Spirng中可以通过jdbc:initialize-database初始化数据库,配置示例如下
<beans profile="test"> <context:property-placeholder ignore-resource-not-found="true" location="classpath*:/application.properties, classpath*:/application.test.properties" /> <!-- Spring Simple连接池 --> <bean id="dataSource" class="org.springframework.jdbc.datasource.SimpleDriverDataSource"> <property name="driverClass" value="${jdbc.driver}" /> <property name="url" value="${jdbc.url}" /> <property name="username" value="${jdbc.username}" /> <property name="password" value="${jdbc.password}" /> </bean> <!-- 初始化数据表结构 --> <jdbc:initialize-database data-source="dataSource" ignore-failures="ALL"> <jdbc:script location="classpath:sql/h2/schema.sql" /> <jdbc:script location="classpath:data/h2/import-data.sql" encoding="UTF-8"/> </jdbc:initialize-database> </beans> |
四、sql语法图
1、SELECT
data:image/s3,"s3://crabby-images/2c7bc/2c7bc566b29bfcb683380bb1e5c236e5e477bda5" alt=""
2、INSERT
data:image/s3,"s3://crabby-images/b7626/b76267713138f06d1f750922dec36c770c2fbb8f" alt=""
3、UPDATE
data:image/s3,"s3://crabby-images/6752d/6752d33929dae4411e8b95852fc63937cd388f7b" alt=""
4、DELETE
data:image/s3,"s3://crabby-images/f7f01/f7f014270eece4b5bbf11b046a7e4e54b12fc738" alt=""
5、BACKUP
data:image/s3,"s3://crabby-images/becc3/becc3af2c3655b1d6a2157eaadccddbf4e6212e9" alt=""
6、EXPLAIN
data:image/s3,"s3://crabby-images/cd72f/cd72f369d0f1ce68a3fca3e81ae5189b43b95754" alt=""
7、MERGE
data:image/s3,"s3://crabby-images/18615/1861532c72fa73c9eec812fb6a4766bc1a27e3c9" alt=""
8、RUNSCRIPT
运行sql脚本文件
data:image/s3,"s3://crabby-images/657a9/657a93f15312d323626e4abb218b61b705565df8" alt=""
9、SCRIPT
根据数据库创建sql脚本
data:image/s3,"s3://crabby-images/07009/07009e0c1f633b2453b80e56b7603f621e209bd2" alt=""
10、SHOW
data:image/s3,"s3://crabby-images/2056e/2056e939ae13d8e0f7f10deaf21617f66521d649" alt=""
11、ALTER INDEX RENAME
data:image/s3,"s3://crabby-images/3b7c5/3b7c5095c7ed5b1860047271e4f32ae4a6272ec6" alt=""
12、ALTER SCHEMA RENAME
data:image/s3,"s3://crabby-images/af2df/af2df2f94e3d829480e2bbbcf83fd8114512ae27" alt=""
13、ALTER SEQUENCE
data:image/s3,"s3://crabby-images/8079c/8079cd65ba964c3fc3bc6dda17042d13964c3e45" alt=""
14、ALTER TABLE
增加列
data:image/s3,"s3://crabby-images/59fac/59fac7c767d91932c713c1785cf49d1e5c3c1f82" alt=""
增加约束
data:image/s3,"s3://crabby-images/077a0/077a05dee35a1a164c0aabcb967120844ea5bcdc" alt=""
修改列
data:image/s3,"s3://crabby-images/e0f9d/e0f9d65e8755e41902314f2fa310885aa0061d79" alt=""
删除列
data:image/s3,"s3://crabby-images/1a3b0/1a3b08958e389f79a8cc367db4c0d47f2de236a3" alt=""
删除序列
data:image/s3,"s3://crabby-images/0df0b/0df0ba31af8968bc667f08d382ce2ea58ad2ed7b" alt=""
15、ALTER USER
修改用户名
data:image/s3,"s3://crabby-images/e8201/e820193b1390e8289326e2b493e046f57d8eb61d" alt=""
修改用户密码
data:image/s3,"s3://crabby-images/7c7c7/7c7c7e90572930cd9886ad4074824ad6d59d8238" alt=""
16、ALTER VIEW
data:image/s3,"s3://crabby-images/e57f3/e57f3babdc68f2d9a839ad60f1712d5c62d00025" alt=""
17、COMMENT
data:image/s3,"s3://crabby-images/f4e78/f4e78ece75782318bfea19c4ef6fa02f9fafebe4" alt=""
18、CREATE CONSTANT
data:image/s3,"s3://crabby-images/2d72d/2d72dfb83f1c2b230268e55d62598c1576872e33" alt=""
19、CREATE INDEX
data:image/s3,"s3://crabby-images/db6b8/db6b842b29c89de2fa520eb87d8ca49b2a221733" alt=""
20、CREATE ROLE
data:image/s3,"s3://crabby-images/2e3af/2e3af42d9c12c35821be2aab13274c86b09a7a1b" alt=""
21、CREATE SCHEMA
data:image/s3,"s3://crabby-images/4e4eb/4e4eb686ea6b41ab5e1a81c9b12c02a446433ca1" alt=""
22、CREATE SEQUENCE
data:image/s3,"s3://crabby-images/a1180/a11807300977c094efc69ed038267dcae9ef69a5" alt=""
23、CREATE TABLE
data:image/s3,"s3://crabby-images/2c8f4/2c8f44c67346233014cfbe59894292878b2404b8" alt=""
24、CREATE TRIGGER
data:image/s3,"s3://crabby-images/b7717/b7717561829a8c49ca10588e4e534c4465f86755" alt=""
25、CREATE USER
data:image/s3,"s3://crabby-images/2b989/2b9896c87261b5c7b865f8636aa2015d608b9b94" alt=""
26、CREATE VIEW
data:image/s3,"s3://crabby-images/18f04/18f041f12cc1aafeda3e84847e5f398958876ac3" alt=""
27、DROP
data:image/s3,"s3://crabby-images/fc12b/fc12bdf186a71693caefc0450a6d8ffca45288f4" alt=""
28、GRANT RIGHT授权
data:image/s3,"s3://crabby-images/7f532/7f5325c60177d0b1052a618773c04efdc770978c" alt=""
给schema授权
data:image/s3,"s3://crabby-images/fd2d9/fd2d9dbf2ad2b0c0342d8d49e54be5dccba673de" alt=""
复制角色的权限
data:image/s3,"s3://crabby-images/f821e/f821e1b905e29a5266cebf4b7cd2ecf7b6ebfa62" alt=""
29、REVOKE RIGHT移除授权
data:image/s3,"s3://crabby-images/509c8/509c8ef1235902a5d250d686908f16bded681879" alt=""
移除角色具有的权限
data:image/s3,"s3://crabby-images/b2b22/b2b22fd12a93355d09be71f1eb7dea4fb779de34" alt=""
30、ROLLBACK
从某个还原点(savepoint)回滚
data:image/s3,"s3://crabby-images/4ade9/4ade96e03a537bcfc5a2469d0eac528c56b95f7e" alt=""
回滚事务
data:image/s3,"s3://crabby-images/7a0ac/7a0ac486536d075fe433e1181f26b32cd54c0473" alt=""
创建savepoint
|