H2数据库-简介

1.美图

在这里插入图片描述

2.简介

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

  1. 第一个用途,也是最常使用的用途就在于可以同应用程序打包在一起发布,这样可以非常方便地存储少量结构化数据。
  2. 第二个用途是用于单元测试。启动速度快,而且可以关闭持久化功能,每一个用例执行完随即还原到初始状态。
  3. 第三个用途是作为缓存,即当做内存数据库,作为NoSQL的一个补充。当某些场景下数据模型必须为关系型,可以拿它当Memcached使,作为后端MySQL/Oracle的一个缓冲层,缓存一些不经常变化但需要频繁访问的数据,比如字典表、权限表。

2.下载安装

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.管理终端

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.200.jar:$H2DRIVERS:$CLASSPATH" org.h2.tools.Console "$@"

# 修改为

#!/bin/sh
dir=$(dirname "$0")
java -cp "$dir/h2-1.4.200.jar:$H2DRIVERS:$CLASSPATH" org.h2.tools.Server -tcpAllowOthers -webAllowOthers -webPort 8082 "$@"

说明

  1. org.h2.tools.Server: 以服务器模式启动
  2. -tcpAllowOthers: 允许远程机器通过TCP方式访问
  3. -webAllowOthers: 允许远程机器通过浏览器访问
  4. -webPort 8082: 默认的访问端口(8082为未被占用的端口,如果此端口已经被其他端口占用,则改为其他端口)

具体的运行方式

chmod修改文件权限;

(base) lcc@lcc bin$ chmod 777 h2_server.sh
(base) lcc@lcc bin$

先直接启动

(base) lcc@lcc bin$ ./h2_server.sh
TCP server running at tcp://localhost:9092 (others can connect)
PG server running at pg://localhost:5435 (only local connections)
Web Console server running at http://localhost:8082 (others can connect)

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

(base) lcc@lcc bin$ nohup ./h2_server.sh &
[1] 7695
(base) lcc@lcc bin$ appending output to nohup.out

(base) lcc@lcc bin$

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

# nohup command &

系统会进入:
在这里插入图片描述

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

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

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

什么都不配置会直接报错
在这里插入图片描述

输入账号和密码(默认账号是sa,密码为空),进入数据库。

但是仍然报错,除非开启自动建库。

参考:https://www.jianshu.com/p/39f92797f9d2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

九师兄

你的鼓励是我做大写作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值