Home > Database > Mysql Tutorial > H2数据库攻略

H2数据库攻略

WBOY
Release: 2016-06-07 15:37:26
Original
1987 people have browsed it

H2是一个开源的嵌入式数据库引擎,采用java语言编写,不受平台的限制,同时H2提供了一个十分方便的web控制台用于操作和管理数据库内容。H2还提供兼容模式,可以兼容一些主流的数据库,因此采用H2作为开发期的数据库非常方便。 Features H2 Derby HSQLDB MySQ

H2是一个开源的嵌入式数据库引擎,采用java语言编写,不受平台的限制,同时H2提供了一个十分方便的web控制台用于操作和管理数据库内容。H2还提供兼容模式,可以兼容一些主流的数据库,因此采用H2作为开发期的数据库非常方便。

Features

  H2 Derby HSQLDB MySQL PostgreSQL
Pure Java Yes Yes Yes No No
Memory Mode Yes Yes Yes No No
Encrypted Database Yes Yes Yes No No
ODBC Driver Yes No No Yes Yes
Fulltext Search Yes No No Yes Yes
Multi Version Concurrency Yes No Yes Yes Yes
Footprint (jar/dll size) ~1 MB ~2 MB ~1 MB ~4 MB ~6 MB

See also the detailed comparison.


一、引入Maven依赖

在maven中定义H2数据库的版本属性

<properties>
        <h2.version>1.3.172</h2.version>
    </properties>ataNode对象
  }
Copy after login

添加H2依赖

 <dependency>
        <groupid>com.h2database</groupid>
        <artifactid>h2</artifactid>
        <version>${h2.version}</version>
        <scope>test</scope>
    </dependency>
Copy after login

二、运行方式

1、在内存中运行

数据库只在内存中运行,关闭连接后数据库将被清空,适合测试环境

连接字符串:

jdbc:h2:mem:DBName;DB_CLOSE_DELAY=-1
Copy after login

如果不指定DBName,则以私有方式启动,只允许一个连接

2、嵌入式

数据库持久化存储为单个文件

连接字符串:

jdbc:h2:file:~/.h2/DBName;AUTO_SERVER=TRUE
Copy after login

~/.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
Copy after login

执行如下命令,获取选项列表及默认值

java -cp h2*.jar org.h2.tools.Server -?
Copy after login

常见的选项如下:

-web:启动支持H2 Console的服务

-webPort :服务启动端口,默认为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>
Copy after login

在命令行中执行如下命令启动H2 Console

mvn exec:java
Copy after login

或者建立一个bat文件

@echo off
call mvn exec:java
pause
Copy after login

此操作相当于执行了如下命令:

java -jar h2-1.3.168.jar -web -webPort 8090 -browser
Copy after login

三、应用程序配置

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=
Copy after login

#connection pool settings
jdbc.pool.maxIdle=5
jdbc.pool.maxActive=40

2、初始化数据库

(1)、在Maven中初始化数据库


<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"></property>
                            <sql driver="${jdbc.driver}" url="${jdbc.url}" userid="${jdbc.username}" password="${jdbc.password}" onerror="continue" encoding="${project.build.sourceEncoding}">
                                <classpath refid="maven.test.classpath"></classpath>
                                <transaction src="src/main/resources/sql/h2/schema.sql"></transaction>
                                <transaction src="src/test/resources/data/h2/import-data.sql"></transaction>
                            </sql>
                        </target>
                    </configuration>
                </plugin>
            </plugins>
        </build>
    </profile>
Copy after login

执行如下命令调用该Profile,初始化数据库

mvn antrun:run -Prefresh-db
Copy after login

(2)、在Spring中初始化数据库

Spring Profile和maven profile一样,也可以模拟不同的开发环境。在Spirng中可以通过jdbc:initialize-database初始化数据库,配置示例如下

<beans profile="test">
        <property-placeholder ignore-resource-not-found="true" location="classpath*:/application.properties,
                      classpath*:/application.test.properties"></property-placeholder>    
        
        <!-- Spring Simple连接池 -->
        <bean id="dataSource" class="org.springframework.jdbc.datasource.SimpleDriverDataSource">
            <property name="driverClass" value="${jdbc.driver}"></property>
            <property name="url" value="${jdbc.url}"></property>
            <property name="username" value="${jdbc.username}"></property>
            <property name="password" value="${jdbc.password}"></property>
        </bean>
    
        <!-- 初始化数据表结构 -->
        <initialize-database data-source="dataSource" ignore-failures="ALL">
            <script location="classpath:sql/h2/schema.sql"></script>
            <script location="classpath:data/h2/import-data.sql" encoding="UTF-8"></script>
        </initialize-database>
    </beans>
Copy after login

四、sql语法图

1、SELECT

H2数据库攻略

2、INSERT

H2数据库攻略

3、UPDATE

H2数据库攻略

4、DELETE

H2数据库攻略

5、BACKUP

H2数据库攻略

6、EXPLAIN

H2数据库攻略

7、MERGE

H2数据库攻略

8、RUNSCRIPT

运行sql脚本文件

H2数据库攻略

9、SCRIPT

根据数据库创建sql脚本

H2数据库攻略

10、SHOW

H2数据库攻略

11、ALTER INDEX RENAME

H2数据库攻略

12、ALTER SCHEMA RENAME

H2数据库攻略

13、ALTER SEQUENCE

H2数据库攻略

14、ALTER TABLE

增加列

H2数据库攻略

增加约束

H2数据库攻略

修改列

H2数据库攻略

删除列

H2数据库攻略

删除序列

H2数据库攻略

15、ALTER USER

修改用户名

H2数据库攻略

修改用户密码

H2数据库攻略

16、ALTER VIEW

H2数据库攻略

17、COMMENT

H2数据库攻略

18、CREATE CONSTANT

H2数据库攻略

19、CREATE INDEX

H2数据库攻略

20、CREATE ROLE

H2数据库攻略

21、CREATE SCHEMA

H2数据库攻略

22、CREATE SEQUENCE

H2数据库攻略

23、CREATE TABLE

H2数据库攻略

24、CREATE TRIGGER

H2数据库攻略

25、CREATE USER

H2数据库攻略

26、CREATE VIEW

H2数据库攻略

27、DROP

H2数据库攻略

28、GRANT RIGHT授权

H2数据库攻略

给schema授权

H2数据库攻略

复制角色的权限

H2数据库攻略

29、REVOKE RIGHT移除授权

H2数据库攻略

移除角色具有的权限

H2数据库攻略

30、ROLLBACK

从某个还原点(savepoint)回滚

H2数据库攻略

回滚事务

H2数据库攻略

创建savepoint

H2数据库攻略

http://www.uml.org.cn/sjjm/201403141.asp

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template