关系型数据库(h2)

概述

纯Java实现开源关系数据库,支持嵌入式、服务器和混合三种运行模式,具备轻量化(约2MB JAR文件)和跨平台特性。该数据库采用多版本并发控制(MVCC)机制优化并发访问性能,支持SQL标准的大部分功能,并兼容MySQL语法。

maven依赖

xml 复制代码
<dependency>
    <groupId>com.h2database</groupId>
    <artifactId>h2</artifactId>
    <version>2.1.210</version>
</dependency>

示例

  • 内存模式
java 复制代码
    @Test
    void contextLoads() throws ClassNotFoundException, SQLException {
        Class.forName("org.h2.Driver");
        Connection connection = DriverManager.getConnection("jdbc:h2:mem:test");
        Statement statement = connection.createStatement();
        //创建表
        statement.execute("create table tb_demo(id integer not null, name TEXT);");
        //插入数据
        statement.execute("insert into tb_demo(id,name) values (1,'bob');");
        statement.execute("insert into tb_demo(id,name) values (2,'pop');");
        //查询数据
        ResultSet resultSet = statement.executeQuery("select * from tb_demo");
        while (resultSet.next()) {
            int id = resultSet.getInt("id");
            String name = resultSet.getString("name");
            System.out.println("id: " + id + "   name: " + name);
        }
    }
  • 文件模式
java 复制代码
    @Test
    void contextLoads1() throws ClassNotFoundException, SQLException {
        Class.forName("org.h2.Driver");
        //文件模式,会将数据库文件存储在指定位置。配置数据库文件生成会自动加 .mv.db 后缀名
        Connection connection = DriverManager.getConnection("jdbc:h2:file:E:\\db\\h2");
        Statement statement = connection.createStatement();
        //创建表
        statement.execute("create table tb_demo(id integer not null, name TEXT);");
        //插入数据
        statement.execute("insert into tb_demo(id,name) values (1,'bob');");
        statement.execute("insert into tb_demo(id,name) values (2,'pop');");
        //查询数据
        ResultSet resultSet = statement.executeQuery("select * from tb_demo");
        while (resultSet.next()) {
            int id = resultSet.getInt("id");
            String name = resultSet.getString("name");
            System.out.println("id: " + id + "   name: " + name);
        }
    }

可参考文档

相关推荐
七度黑光4 小时前
用 openclaw 给故障复盘打分:质量审核自动化实践
运维·服务器·前端·数据库·自动化
华科易迅6 小时前
Spring 事务(注解)
java·数据库·spring
Java面试题总结6 小时前
MySQL篇 索引失效
数据库·mysql
last demo6 小时前
mysql
运维·数据库·mysql·oracle
kevin_cat7 小时前
oracle 扩展表空间
数据库·oracle
花间相见8 小时前
【MySQL面试题】—— MySQL面试高频问题汇总:从原理到实战,覆盖90%考点
数据库·mysql·面试
高梦轩9 小时前
MySQL 数据库备份与恢复
数据库·oracle
一直都在5729 小时前
Redis(二)
数据库·redis·缓存
TDengine (老段)9 小时前
TDengine IDMP 工业数据建模 —— 属性
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
爱丽_10 小时前
Redis 分布式锁:SET NX、过期时间、续租、可重入、Redlock 与坑
数据库·redis·分布式