H2DataBase的简单使用

这几天因为业务需要,就简单了解了一下H2数据库,顺带记一下笔记。

一、简介

下面是官网的一段话

/**
 * Very fast, open source, JDBC API,
 * Embedded and server modes; in-memory databases
 * Browser based Console application
 * Small footprint: around 2 MB jar file size
 **/

大概意思就是说,这个数据库是开源的非常快,并且可以使用jdbc api来操作,有内嵌式和服务两种运行模式,并且是基于内存的数据库,还可以基于浏览器的客户端进行操作,jar包非常小,只需要2mb的jar包就可以运行,所以有些需要数据比较小的缓存的时候,可以考虑一下H2,毕竟搭建redis相对还是比较麻烦的,而且成本也较高。

二、项目中使用H2的流程

1、导入依赖

我使用的是idea,可以直接在maven项目的pom文件中添加依赖就可以了,如果是eclipse则需要到maven仓库或者官网下载jar包,手动添加了

<!-- https://mvnrepository.com/artifact/com.h2database/h2 -->
<dependency>
    <groupId>com.h2database</groupId>
    <artifactId>h2</artifactId>
    <version>1.4.197</version>
    <scope>test</scope>
</dependency>

2、配置运行模式

2.1、内嵌式

内嵌式主要有两种,一种是内存模式,这种模式不会落地持久化,所以比较适合测试,关闭连接后数据库就清空,只需要添加

private static final String JDBC_URL = "jdbc:h2:mem:DBName;DB_CLOSE_DELAY=-1";

另外一种是持久化模式,这种模式会将数据落地持久化到指定的目录,生成与数据库同名的.mv.db文件

private static final String JDBC_URL = "jdbc:h2:./test";
2.2、服务式

服务式就是指定一个tcp的远程目录

private static final String JDBC_URL = "jdbc:h2:tcp://localhost/~/test”;

3、配置连接参数

url在前面已经配置过了,剩下的就是一些基本配置,比如用户名、密码等

    //用户名
    private static final String USER = "sa";
    //连接数据库时使用的密码,默认为空
    private static final String PASSWORD = "";
    //连接H2数据库时使用的驱动类,org.h2.Driver这个类是由H2数据库自己提供的,在H2数据库的jar包中可以找到
    private static final String DRIVER_CLASS = "org.h2.Driver";

4、创建连接

然后就可以根据前面的参数创建一个连接了

// 加载H2数据库驱动
Class.forName(DRIVER_CLASS);
// 根据连接URL,用户名,密码获取数据库连接
Connection conn = DriverManager.getConnection(JDBC_URL, USER, PASSWORD);

5、简单的使用

现在我们就可以根据前面创建的连接,进行各种操作了,H2数据库基本类似于Mysql,所以语句也基本相同,另外H2添加自定义函数也很简单,创建一个类,类里定义一个静态的公共方法,然后执行下面的语句就可以添加一个函数了

// functionName 为H2中使用的名字,不能重名,package.className.functionName则是方法的路径,从包名到方法名都需要加上
CREATE ALIAS IF NOT EXISTS  functionName FOR "package.className.functionName"

6、注意

在使用中我注意到的就是H2的视图并不是随原表更新的,其他的还有待发现。

H2的本地使用

1、下载jar包

这一步参考前面的导入依赖,将jar包下载到本地

2、运行

打开cmd.exe(window,linux未测试),然后使用java -jar jar包路径,就可以运行H2数据库了,他会自动打开网页的客户端,默认使用的是持久化模式,可以用来测试语句等。

目前简单的使用就到这里了,如果有什么错误或者问题欢迎指正和评论

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值