H2数据库 | 学习总结

简介: H2数据库

1. maven配置


<!--H2数据库-->

   <!-- https://mvnrepository.com/artifact/com.h2database/h2 -->

   <dependency>

     <groupId>com.h2database</groupId>

    <artifactId>h2</artifactId>

    <version>RELEASE</version>

    <scope>compile</scope>

   </dependency>


2. 简介


H2 是一款短小精干、性能强劲的基于 Java 内存、开源的关系型数据库。H2是一个嵌入式数据库引擎,采用java语言编写,不受平台的限制,同时支持网络版和嵌入式版本,有比较好的兼容性,支持相当标准的sql标准,支持集群。提供JDBC、ODBC访问接口,提供了非常友好的基于web的数据库管理界面。


3. 特性


  • 非常快的数据库引擎
  • 开源
  • Java 编写
  • 支持标准 SQL, JDBC API
  • 内嵌和服务器模式,支持集群
  • 强大的安全特性
  • 可使用 PostgreSQL ODBC
  • 多版本并发
  • 基于磁盘或者内存数据库和表,支持只读数据库,临时表
  • 支持事务(read committed),两阶段提交
  • 多连接,表级锁


4. 连接方式


本地连接


以嵌入式(本地)连接方式连接H2数据库。
这种连接方式默认情况下只允许有一个客户端连接到H2数据库,有客户端连接到H2数据库之后,此时数据库文件就会被锁定,那么其他客户端就无法再连接了。


连接语法:jdbc:h2:[file:][]


例如:
    jdbc:h2:~/test //连接位于用户目录下的test数据库
    jdbc:h2:file:/data/sample
    jdbc:h2:file:E:/H2/gacl(Windows only)


   //本地连接

   private static final String JDBC_URL_LOCAL = "jdbc:h2:C://localhost/~/test";


  • H2数据库被称为内存数据库,因为它支持在内存中创建数据库和表
  • 注意:如果使用H2数据库的内存模式,那么我们创建的数据库和表都只是保存在内存中,一旦服务器重启,那么内存中的数据库和表就不存在了。


远程连接


使用TCP/IP的服务器模式(远程连接)方式连接H2数据库(推荐)。这种连接方式就和其他数据库类似了,是基于Service的形式进行连接的,因此允许多个客户端同时连接到H2数据库。


连接语法:jdbc:h2:tcp://[:]/[]
  范例:jdbc:h2:tcp://localhost/~/test


   //远程连接

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


连接方式对比

连接方式

语法

示例

优点

缺点

本地连接

jdbc:h2:[file:][<\path>]<\databaseName>

jdbc:h2:C://localhost/~/test

连接快,操作方便

仅支持一个连接;无持久化

远程连接

jdbc:h2:tcp://<\server>[:<\port>]/[<\path>]<\databaseName>

jdbc:h2:tcp://localhost/~/test

支持多连接;支持持久化

需要下载服务端支持


5. 控制台


它提供了交互友好的数据库管理页面,可以下载控制台工具http://www.h2database.com/html/main.html

选择以上控制台,点击打开

以上弹出的浏览器界面类似mysql的Navicat等数据库管理工具,这里不做赘述。

数据库管理后台页面,可以支持SQL语句正常查询和变更操作。


6. 数据库操作


/**

* created by guanjian on 2020/11/23 17:16

*/

public class TestH2 {


   /**

    * 以嵌入式(本地)连接方式连接H2数据库

    */

   //private static final String JDBC_URL = "jdbc:h2:C:/H2/abc";


   /**

    * 使用TCP/IP的服务器模式(远程连接)方式连接H2数据库(推荐)

    */

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

    /**

    * 使用本地模式(内存模式)方式连接H2数据库

    */

   private static final String JDBC_URL_LOCAL = "jdbc:h2:C://localhost/~/test";


   private static final String USER = "sa";

   private static final String PASSWORD = "";

   private static final String DRIVER_CLASS = "org.h2.Driver";


   public static void main(String[] args) throws Exception {

       Class.forName(DRIVER_CLASS);

       Connection conn = DriverManager.getConnection(JDBC_URL_REMOTE, USER, PASSWORD);

       Statement statement = conn.createStatement();

       statement.execute("DROP TABLE IF EXISTS USER_INF");

       statement.execute("CREATE TABLE USER_INF(id INTEGER PRIMARY KEY ,name VARCHAR(100), sex VARCHAR(2))");


       statement.executeUpdate("INSERT INTO USER_INF VALUES(1, 'tom', '男') ");

       statement.executeUpdate("INSERT INTO USER_INF VALUES(2, 'jack', '女') ");

       statement.executeUpdate("INSERT INTO USER_INF VALUES(3, 'marry', '男') ");

       statement.executeUpdate("INSERT INTO USER_INF VALUES(4, 'lucy', '男') ");


       ResultSet resultSet = statement.executeQuery("select * from USER_INF");


       while (resultSet.next()) {

           System.out.println(resultSet.getInt("id") + ", " + resultSet.getString("name") +

                   ", " + resultSet.getString("sex"));

       }


       statement.close();

       conn.close();

   }

}


#TODO 简单整理下,以后使用深入了再研究,目前的定位是一个内存级、性能尚可、支持操作SQL的本地内存


7. 参考资料


https://www.ctolib.com/docs/sfile/h2-database-doc/index.html
https://www.jianshu.com/p/1e0fb830cbe4
https://www.cnblogs.com/simoncook/p/5188105.html

相关文章
|
2月前
|
Java 数据库连接 测试技术
SpringBoot入门 - 添加内存数据库H2
SpringBoot入门 - 添加内存数据库H2
66 3
SpringBoot入门 - 添加内存数据库H2
|
2月前
|
Java 数据库连接 测试技术
SpringBoot入门(4) - 添加内存数据库H2
SpringBoot入门(4) - 添加内存数据库H2
56 4
SpringBoot入门(4) - 添加内存数据库H2
|
13天前
|
存储 JSON NoSQL
学习 MongoDB:打开强大的数据库技术大门
MongoDB 是一个基于分布式文件存储的文档数据库,由 C++ 编写,旨在为 Web 应用提供可扩展的高性能数据存储解决方案。它与 MySQL 类似,但使用文档结构而非表结构。核心概念包括:数据库(Database)、集合(Collection)、文档(Document)和字段(Field)。MongoDB 使用 BSON 格式存储数据,支持多种数据类型,如字符串、整数、数组等,并通过二进制编码实现高效存储和传输。BSON 文档结构类似 JSON,但更紧凑,适合网络传输。
48 15
|
3月前
|
Java 数据库连接 测试技术
SpringBoot入门(4) - 添加内存数据库H2
SpringBoot入门(4) - 添加内存数据库H2
37 2
SpringBoot入门(4) - 添加内存数据库H2
|
2月前
|
Java 数据库连接 测试技术
SpringBoot入门(4) - 添加内存数据库H2
SpringBoot入门(4) - 添加内存数据库H2
72 13
|
2月前
|
Java 数据库连接 测试技术
SpringBoot入门(4) - 添加内存数据库H2
SpringBoot入门(4) - 添加内存数据库H2
57 4
|
3月前
|
SQL NoSQL 关系型数据库
数据库学习
【10月更文挑战第8天】
33 1
|
3月前
|
关系型数据库 MySQL Java
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
这篇文章是关于如何使用Django框架配置MySQL数据库,创建模型实例,并自动或手动创建数据库表,以及对这些表进行操作的详细教程。
109 0
Django学习二:配置mysql,创建model实例,自动创建数据库表,对mysql数据库表已经创建好的进行直接操作和实验。
|
3月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
333 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
3月前
|
Java 关系型数据库 MySQL
springboot学习四:springboot链接mysql数据库,使用JdbcTemplate 操作mysql
这篇文章是关于如何使用Spring Boot框架通过JdbcTemplate操作MySQL数据库的教程。
118 0
springboot学习四:springboot链接mysql数据库,使用JdbcTemplate 操作mysql