【学习总结】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

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要连接H2数据库,可以按照以下步骤: 1. 下载H2数据库:从H2官网(http://www.h2database.com/html/main.html)下载最新的H2数据库版本并解压缩。 2. 启动H2数据库:在解压缩的H2数据库目录下,运行h2.bat(Windows下)或者h2.sh(Linux下)来启动H2数据库。 3. 创建数据库:在H2数据库的控制台中,使用CREATE DATABASE语句来创建一个新的数据库。 4. 连接数据库:在Java程序中,使用JDBC API来连接到H2数据库。示例代码如下: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class H2DatabaseConnection { public static void main(String[] args) { // JDBC driver name and database URL final String JDBC_DRIVER = "org.h2.Driver"; final String DB_URL = "jdbc:h2:tcp://localhost/~/test"; // Database credentials final String USER = "sa"; final String PASS = ""; Connection conn = null; try { // Register JDBC driver Class.forName(JDBC_DRIVER); // Open a connection System.out.println("Connecting to database..."); conn = DriverManager.getConnection(DB_URL, USER, PASS); // Do something with the connection... } catch (SQLException se) { // Handle errors for JDBC se.printStackTrace(); } catch (Exception e) { // Handle errors for Class.forName e.printStackTrace(); } finally { // Close the connection try { if (conn != null) { conn.close(); } } catch (SQLException se) { se.printStackTrace(); } } } } ``` 在上面的示例代码中,JDBC驱动程序的类名为org.h2.Driver,数据库URL为jdbc:h2:tcp://localhost/~/test,其中localhost表示数据库服务器所在的主机名,test是数据库名称。用户名和密码为空。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

大摩羯先生

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值