springboot+H2数据库使用教程

一、前言

H2 是一个用 Java 开发的嵌入式数据库,它本身只是一个类库,即只有一个 jar 文件,可以直接嵌入到应用项目中。H2 主要有如下三个用途:

第一个用途,也是最常使用的用途就在于可以同应用程序打包在一起发布,这样可以非常方便地存储少量结构化数据。

第二个用途是用于单元测试。启动速度快,而且可以关闭持久化功能,每一个用例执行完随即还原到初始状态。

第三个用途是作为缓存,即当做内存数据库,作为NoSQL的一个补充。当某些场景下数据模型必须为关系型,可以拿它当Memcached使,作为后端MySQL/Oracle的一个缓冲层,缓存一些不经常变化但需要频繁访问的数据,比如字典表、权限表。

二、下载安装

2.1 下载

h2 数据库下载地址:http://www.h2database.com/html/main.html 或者http://www.h2database.com/html/download.html


选择 "All Platforms" 版本,是一个压缩包,解压后即可使用既可用于 Windows 平台,也可用于 Linux 平台。

2.2 H2 目录结构

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构建脚本

三、管理终端

3.1 启动

进入H2 的 bin 目录,如果在 Window 环境下使用,可以运行 h2.bat 或 h2w.bat。区别只是后者是后台静默运行。

如果你在 Linux 环境下,可运行./h2.sh 文件来启动数据库服务。但不建议这样直接启动,因为还有一些参数可以设置。可进行如下修改:

1)复制h2.sh为h2_server.sh文件;

2)编辑h2_server.sh,如下:

#!/bin/sh

dir=$(dirname"$0")

java -cp "$dir/h2-1.4.197.jar:$H2DRIVERS:$CLASSPATH" org.h2.tools.Server -tcpAllowOthers -webAllowOthers -webPort 8082 "$@"

3)说明:

org.h2.tools.Server: 以服务器模式启动

-tcpAllowOthers: 允许远程机器通过TCP方式访问

-webAllowOthers: 允许远程机器通过浏览器访问

-webPort 8082: 默认的访问端口(8082为未被占用的端口,如果此端口已经被其他端口占用,则改为其他端口)

4)具体的运行方式

chmod修改文件权限;

输入nohup ./h2_server.sh & 回车。这样可以后台运行。

nohup 命令可以在你退出账户之后继续运行相应的进程。nohup 就是不挂起的意思(no hang up)。& 表示让该进程实现后台运行。该命令的一般形式为:

'# nohup command &'

比如运行了 h2.bat,系统会进入:


或者自己打开浏览器,输入地址:http://localhost:8082访问 H2 数据库的 Web Console。这里就需要说明一下 "" 这个符号在window操作系统下代表什么意思,在Window操作系统下,""这个符号代表的就是当前登录到操作系统的用户对应的用户目录,与 Linux 系统中的意义相同,代表用户家目录。

最上方可以选择 language,可以进行语言切换。如切换成中文:


点击蓝色字体配置,可以跳转到配置H2数据库的另一个页面,点击工具,会给你提供一堆对H2数据库操作的功能,比如:备份、还原、恢复、集群、运行脚本、删除文件等等。点击帮助,会提示一些关于 H2 数据库使用的帮助信息。接下来就是最重要的配置数据库连接信息,驱动类和 JDBC URL 是默认的,如果你想创建一个新的数据库,直接修改 jdbc:h2:[输入你想创建的数据库文件的路径],就可以为你自动创建一个新的数据库(在指定路径下会创建对应的数据库文件 xxxx.mv.db),用户名密码由用户自行定义,连接数据库之前还可以点击测试连接,测试是否可以正确连接。


生成的数据库文件:


可选配置


在用户目录下新建 .h2.server.properties,支持如下属性配置:

webAllowOthers: 是否允许远程连接,默认 false。

webPort: h2 端口,默认为 8082。

webSSL: 是否启用 SSL 加密连接,默认 false。

webAdminPassword: 超级管理员密码。


如果没有手动配置此文件,以 web-server 方式首次启动 H2 后,点击打开的浏览器页面的 Save 按钮后就会自动创建一个。


.h2.server.properties 文件范例:

#H2 Server Properties

#Wed Jul 01 23:00:28 CST 2020

0=Generic JNDI Data Source|javax.naming.InitialContext|java\:comp/env/jdbc/Test|sa

1=Generic Teradata|com.teradata.jdbc.TeraDriver|jdbc\:teradata\://whomooz/|

10=Generic DB2|com.ibm.db2.jcc.DB2Driver|jdbc\:db2\://localhost/test|

11=Generic Oracle|oracle.jdbc.driver.OracleDriver|jdbc\:oracle\:thin\:@localhost\:1521\:XE|sa

12=Generic MS SQL Server 2000|com.microsoft.jdbc.sqlserver.SQLServerDriver|jdbc\:microsoft\:sqlserver\://localhost\:1433;DatabaseName\=sqlexpress|sa

13=Generic MS SQL Server 2005|com.microsoft.sqlserver.jdbc.SQLServerDriver|jdbc\:sqlserver\://localhost;DatabaseName\=test|sa

14=Generic PostgreSQL|org.postgresql.Driver|jdbc\:postgresql\:test|

15=Generic MySQL|com.mysql.jdbc.Driver|jdbc\:mysql\://localhost\:3306/test|

16=Generic HSQLDB|org.hsqldb.jdbcDriver|jdbc\:hsqldb\:test;hsqldb.default_table_type\=cached|sa

17=Generic Derby (Server)|org.apache.derby.jdbc.ClientDriver|jdbc\:derby\://localhost\:1527/test;create\=true|sa

18=Generic Derby (Embedded)|org.apache.derby.jdbc.EmbeddedDriver|jdbc\:derby\:test;create\=true|sa

19=Generic H2 (Server)|org.h2.Driver|jdbc\:h2\:tcp\://localhost/~/test|sa

2=Generic Snowflake|com.snowflake.client.jdbc.SnowflakeDriver|jdbc\:snowflake\://accountName.snowflakecomputing.com|

20=Generic H2 (Embedded)|org.h2.Driver|jdbc\:h2\:~/test|root

3=Generic Redshift|com.amazon.redshift.jdbc42.Driver|jdbc\:redshift\://endpoint\:5439/database|

4=Generic Impala|org.cloudera.impala.jdbc41.Driver|jdbc\:impala\://clustername\:21050/default|

5=Generic Hive 2|org.apache.hive.jdbc.HiveDriver|jdbc\:hive2\://clustername\:10000/default|

6=Generic Hive|org.apache.hadoop.hive.jdbc.HiveDriver|jdbc\:hive\://clustername\:10000/default|

7=Generic Azure SQL|com.microsoft.sqlserver.jdbc.SQLServerDriver|jdbc\:sqlserver\://name.database.windows.net\:1433|

8=Generic Firebird Server|org.firebirdsql.jdbc.FBDriver|jdbc\:firebirdsql\:localhost\:c\:/temp/firebird/test|sysdba

9=Generic SQLite|org.sqlite.JDBC|jdbc\:sqlite\:test|sa

webAllowOthers=false

webPort=8082

webSSL=false

webAdminPassword=111111

spring boot2.x中集成H2数据库

添加依赖:

<dependency>

    <groupId>com.h2database</groupId>

    <artifactId>h2</artifactId>

    <version>2.1.214</version>

</dependency>

注意:这里的version需要与生成db文件的版本一致,否则可能会报如下错误:

org.h2.jdbc.JdbcSQLException: File corrupted while reading record: null. Possible solution: use the recovery tool [90030-195]


创建application.yml

server:

  port: 8080

spring:

  application:

    name: service-h2

  datasource:

    driver-class-name: org.h2.Driver

    url: jdbc:h2:./db/face

    username: root

    password: 111111

  h2:

    console:

      enabled: true

      path: /h2

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容