这几天因为业务需要,就简单了解了一下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、配置运行模式
内嵌式主要有两种,一种是内存模式,这种模式不会落地持久化,所以比较适合测试,关闭连接后数据库就清空,只需要添加
private static final String JDBC_URL = "jdbc:h2:mem:DBName;DB_CLOSE_DELAY=-1";
另外一种是持久化模式,这种模式会将数据落地持久化到指定的目录,生成与数据库同名的.mv.db文件
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数据库了,他会自动打开网页的客户端,默认使用的是持久化模式,可以用来测试语句等。
目前简单的使用就到这里了,如果有什么错误或者问题欢迎指正和评论
————————————————
版权声明:本文为优快云博主「CSwhit」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.youkuaiyun.com/cswhit/article/details/89489406