当前位置: 首页 > news >正文

内存数据库Apache Derby、H2

概述

传统关系型数据库涉及大量的工作,如果想在Java应用程序里使用MySQL数据库,至少需要如下步骤:

  • 安装(可选:配置用户名密码)
  • 建表(要么从命令行进入,要么安装一个可视化工具,如DataGrip)
  • 插入数据(可选)
  • 配置连接信息(数据库的连接串,用户名,密码等信息)

还是有些繁琐。想象如下场景:

  1. 想要快速进行POC(Proof of Concept)概念验证测试
  2. 考虑单元测试
    • 当数据库中的某些数据/模式发生更改时,不希望它们失败
    • 可能希望能够并行运行它们,多个开发人员可能并行运行测试。

此时,内存数据库(In-Memory Database,嵌入式数据库)可提供一种较为理想的解决方案。在Java应用程序启动时创建内存数据库,并在应用程序停止时销毁。好处:

  • 零项目设置或基础设施
  • 零配置零维护
  • 易于学习,POC和单元测试

总结,以存储介质来分类,数据库有两种:

  • 内存数据库:数据主要存储在内存中,可将数据进行持久化到文件硬盘中。如Redis、H2DB的内存模式。由于内存容量有限,不适合大型应用。
  • 硬盘数据库:最为常见。如SSDB是基于SSD硬盘的KV数据库,支持的数据接口很丰富,是Redis的另外一个选择。

举例

如SQLite、Berkeley DB、Derby、H2、HSQL DB、MySQL Embedded都是内存数据库。

Derby

官网
Apache Derby是100% Java编写,安装简单易管理,体积小,与平台无关的内存数据库,以 Java 类库的形式对外提供服务。支持的数据库最大50GB,支持标准SQL92,SQL1999,SQL2003,临时表,索引,触发器,视图,存储过程,外键,约束,并行,事务,加密与安全等。性能较好,在插入100万条记录时,CPU占用率一直低于 40%,平均每插一条记录耗时小于 0.3 毫秒。

支持两种运行模式:

  1. 内嵌模式:数据库与应用程序共享同一个JVM,通常由应用程序负责启动和停止,对除启动它的应用程序外的其它应用程序不可见,即其它应用程序不可访问它;
  2. 网络模式:数据库独占一个JVM,做为服务器上的一个独立进程运行。在这种模式下,允许有多个应用程序来访问同一个Derby数据库。

下载地址,需根据JDK版本下载相应的Derby版本。目前还在使用JDK8,故下载db-derby-10.14.2.0-bin.zip版本,解压后的目录:

  1. bin:工具脚本和设备环境的脚本;
  2. demo:实例程序;
  3. docs:文档;
  4. javadoc:API文档;
  5. lib:jar文件;
  6. test:测试jar包;

命令行

bin目录提供ij脚本。

D:\Program\db-derby-10.14.2.0-bin\bin> ./ij.bat
ij 版本 10.14
ij> show databases
> # 输出为空,表明此时没有任何数据库
> connect 'jdbc:derby:mydb;create=true';
IJ 错误:无法建立 connection # 连接数据库,没有则创建
ij> connect 'jdbc:derby:e:/mydb;create=true'; # 必须指定路径
ij> # 输出为空,表示执行成功无报错

看一下本地生成的目录:
在这里插入图片描述
接下来可以像MySQL那样操作:

ij> create table test(id int primary key, name varchar(22));
已插入/更新/删除 0 行
ij> insert into test values(1,'johnny');
已插入/更新/删除 1 行
ij> select * from test
> ; # 语句必须以英文分号结尾
ID         |NAME
----------------------------------
1          |johnny
已选择 1 行
ij> disconnect; # 断开连接
ij> exit; # 退出,Ctrl+C

Java

Maven添加如下依赖:

<dependency><groupId>org.apache.derby</groupId><artifactId>derby</artifactId><version>10.14.2.0</version><scope>test</scope>
</dependency>

注意需要根据JDK版本号添加相应的Derby版本,JDBC demo示例代码略,过于简单。

H2

Spring Boot已经是Java开发者事实上的标准。SB提供简单配置,可在真实数据库(如MySQL)和内存数据库(如H2)之间切换。

H2是用Java编写的关系数据库管理系统,可嵌入Java应用程序中,也可以在客户端 - 服务器模式下运行。支持SQL标准的子集,还提供一个Web控制台(h2-console)来查看和维护数据库。使用时加入H2运行时依赖

<dependency><groupId>com.h2database</groupId><artifactId>h2</artifactId><scope>runtime</scope>
</dependency>

application.properties中启用h2控制台功能:spring.h2.console.enabled=true
启动应用程序,可看到控制台打印输出:

o.s.b.a.h2.H2ConsoleAutoConfiguration    : H2 console available at '/h2-console'. Database available at 'jdbc:h2:mem:dc2f642f-cc93-48df-b170-4110b17384c3'

浏览器访问http://localhost:<server.port>/h2-console/,会自动跳转到http://localhost:8085/h2-console/login.jsp?jsessionid=e8c8fb0e00f5dff6fa6f59636cbb26c6,jsessionid每次都不一样。
在这里插入图片描述
注意上图中的JDBC URL默认为jdbc:h2:~/test,此时如果直接点Connect或Test Connection,都会报错,报错信息如上:Database not found。注意看应用启动时的控制台输出的关键信息。填入dc2f642f-cc93-48df-b170-4110b17384c3,然后点击Connect。成功,挑战到页面:
在这里插入图片描述
可以看到此界面和DataGrip还是有点相似,左侧是库和表信息,右边是SQL编辑框,上面有一些配置项,下面有命令解释和示例SQL脚本。最下面截图不完整的Adding Database Drivers

Additional database drivers can be registered by adding the Jar file location of the driver to the environment variables H2DRIVERS or CLASSPATH. Example (Windows): to add the database driver library C:/Programs/hsqldb/lib/hsqldb.jar, set the environment variable H2DRIVERS to C:/Programs/hsqldb/lib/hsqldb.jar.

大意是可以设置环境变量H2DRIVERS=<path_to_hsqldb.jar_file>

进阶

SB自动配置原理,在类路径中看到H2,就会自动配置数据源:

spring.datasource.url=jdbc:h2:mem:<uuid>
spring.datasource.driverClassName=org.h2.Driver
spring.datasource.username=sa
spring.datasource.password=
spring.jpa.database-platform=org.hibernate.dialect.H2Dialect

即,如果没有提供URL指定库名和表名,会使用UUID规则生成一个数据库

持久化
应用程序退出后,数据会从内存清除,怎么把数据持久化呢?H2提供持久化到文件的配置:

spring:datasource:driver-class-name: org.h2.Driverurl: jdbc:h2:file:/www/${spring.application.name}/db# Windows# url: jdbc:h2:file:C:/data/sample/${spring.application.name}/db;# 内存数据配置# spring.datasource.url=jdbc:h2:mem:testdbusername: sapassword:jpa:hibernate:ddl-auto: updatedatabase-platform: org.hibernate.dialect.H2Dialecth2:console:path: /h2enabled: truesettings:web-allow-others: true

可结合JPA或Spring Data JDBC一起使用,下面是JPA引入:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>

@Entity标注实体类,@Id标注主键:

@Entity
public class Product {@javax.persistence.Idprivate String Id;private String name;
}

其他无需任何配置,SB启动时发现classpath中有m2就默认启动,同时建立product对应的H2数据表。

参考

  • h2-file-database
  • 内存数据库的发展现状和前景如何

相关文章:

内存数据库Apache Derby、H2

概述 传统关系型数据库涉及大量的工作&#xff0c;如果想在Java应用程序里使用MySQL数据库&#xff0c;至少需要如下步骤&#xff1a; 安装&#xff08;可选&#xff1a;配置用户名密码&#xff09;建表&#xff08;要么从命令行进入&#xff0c;要么安装一个可视化工具&…...

麻省理工出版 | 2023年最新深度学习综述手册

UCL Simon Prince的新书&#xff1a;《Understanding Deep Learning》 &#xff0c;在2023年2月6日由MIT Press出版。他之前写过很受欢迎的《Computer Vision: Models, Learning, and Inference》。 关于这本最新的深度学习手册&#xff0c;作者这样介绍它&#xff1a; 正如书…...

vi命令详解

VIM - Vi IMproved 7.4 (2013 Aug 10, compiled Oct 13 2020 16:04:38) 用法: vim [参数] [文件 …] 编辑指定的文件 或: vim [参数] - 从标准输入(stdin)读取文本 或: vim [参数] -t tag 编辑 tag 定义处的文件 或: vim [参数] -q [errorfile] 编辑第一个出错处的文件 参数:…...

抖音的外卖行业入局,为中小外卖企业创业者的机会给了哪些机会?

一则关于抖音进入外卖市场的消息&#xff0c;让美团“非常受伤”。 2月8日&#xff0c;美团(03690.HK&#xff09;盘中跌幅超9%。截至收盘&#xff0c;美团报收153.1港元&#xff0c;跌幅6.48%。美团大幅下跌的根源就是前一天关于抖音外卖进展的消息传闻。 2月7日&#xff0c…...

供应PEG试剂AC-PEG-COOH,Acrylate-PEG-Acid,丙烯酸酯-PEG-羧基

英文名称&#xff1a;AC-PEG-COOH&#xff0c;Acrylate-PEG-Acid 中文名称&#xff1a;丙烯酸酯-聚乙二醇-羧基 丙烯酸酯-PEG-COOH是一种含有丙烯酸酯和羧酸的线性杂双功能PEG试剂。它是一种有用的带有PEG间隔基的交联剂。丙烯酸酯可与紫外光或自由基引发剂聚合。丙烯酸酯-PE…...

java二叉排序树

1.先看一个需求 给你一个数列 (7, 3, 10, 12, 5, 1, 9)&#xff0c;要求能够高效的完成对数据的查询和添加 2.解决方案分析 使用数组 数组未排序&#xff0c; 优点&#xff1a;直接在数组尾添加&#xff0c;速度快。 缺点&#xff1a;查找速度慢. [示意图] 数组排序&#xf…...

聊一聊 gRPC 的四种通信模式

温馨提示&#xff1a;本文需要结合上一篇 gRPC 文章一起食用&#xff0c;否则可能看不懂。 前面一篇文章松哥和大家聊了 gRPC 的基本用法&#xff0c;今天我们再来稍微深入一点点&#xff0c;来看下 gRPC 中四种不同的通信模式。 gRPC 中四种不同的通信模式分别是&#xff1a;…...

科技云报道:开源真的香,风险知多少?

科技云报道原创。 过去几年&#xff0c;开源界一片火热&#xff0c;开源软件技术已全面进军操作系统、云原生、人工智能、大数据、半导体、物联网等行业领域。 数据显示&#xff0c;我国超九成企业在使用或正计划使用开源技术。 与此同时&#xff0c;全球各大开源组织相继兴…...

国产化适配迁移记录

国产化适配迁移记录 本项目基于RuoYi-Vue的框架进行迁移。目前已完成覆盖测试暂无其他问题。 国产化环境 名称版本达梦数据库DmJdbcDriver18 8.1.2.144通用mapper – tk.mybatismapper-spring-boot-starter 4.2.5<!-- 达梦数据库--><dependency><groupId>…...

又一国产开源项目走向世界,百度RPC框架Apache bRPC正式成为ASF顶级项目

2023 年 1 月 26 日&#xff0c;Apache 软件基金会 (ASF) 官方正式宣布Apache bRPC 正式毕业&#xff0c;成为 Apache的顶级项目。 我听到这个消息是挺开心的&#xff0c;毕竟是又一款由国人主导的apche顶级项目&#xff0c;再次证明国内在开源界正在发挥越来越重要的作用。 …...

多数据库学习之GBase8s查询数据库表元信息常用SQL

多数据库学习之GBase8s查询数据库表元信息常用SQL简介常用SQL创建用户创建数据库及模式获取表元数据其他参考链接简介 背景介绍 GBase 8t是基于IBM informix源代码、编译和测试体系自主研发的交易型数据库产品。 南大通用安全数据库管理系统&#xff08;简称 GBase 8s&#xff…...

Jetpack之Lifecycle应用与源码分析

Build lifecycle-aware components that can adjust behavior based on the current lifecycle state of an activity or fragment. 上面是源于官网的定义&#xff0c;简单翻译就是说Lifecycle的作用就是基于当前的Activity或者Fragment的生命周期当前状态构建可感知生命周期的…...

Python序列类型之集合

&#x1f490;&#x1f490;&#x1f490;欢迎来到小十一的博客&#xff01;&#xff01;&#xff01; &#x1f3af;博客主页&#xff1a;&#x1f3af;程序员小十一的博客 &#x1f680;博客专栏&#xff1a;&#x1f680;Python入门基础语法 &#x1f337;欢迎关注&#xff…...

java 自定义json解析注解 复杂json解析

java 自定义json解析注解 复杂json解析 工具类 目录java 自定义json解析注解 复杂json解析 工具类1.背景2、需求-各式各样的json一、一星难度json【json对象中不分层】二、二星难度json【json对象中出现层级】三、三星难度json【json对象中存在数组】四、四星难度json【json对象…...

Vue3配置路由(vue-router)

文章目录前言一、配置路由&#xff08;vue-router&#xff09;1、安装路由2、新建页面3、创建路由配置文件4.特殊报错&#xff01;前言 紧接上篇文章&#xff0c;vue3的配置与vue2是有所差别的&#xff0c;本文就讲述了如何配置&#xff0c;如果本文对你有所帮助请三连支持博主…...

【代码随想录二刷】Day9-字符串-C++

代码随想录二刷Day9 今日任务 28.找出字符串中第一个匹配项的下标 459.重复的子字符串 字符串总结 双指针总结 语言&#xff1a;C KMP 链接&#xff1a;https://programmercarl.com/0459.重复的子字符串.html#kmp 用处&#xff1a;当出现字符串不匹配时&#xff0c;可以利…...

google colab上如何下载bert相关模型

首先要知道模型的地址 tensorflow版本的模型&#xff1a; https://storage.googleapis.com/bert_models/2018_10_18/cased_L-12_H-768_A-12.zip https://storage.googleapis.com/bert_models/2018_11_03/chinese_L-12_H-768_A-12.zip pytorch版本的模型 ‘bert-base-cased’: …...

Vue2.0页面缓存机制联合页面标签的交互(keep-alive + router)

预期效果&#xff1a;&#xff08;借助iview-ui的在线体验页面示意一下&#xff09; 项目中只有一部分页面需要缓存&#xff0c;且存在多级路由的页面。每打开一个菜单&#xff0c;就会新增一个 Tab标签&#xff0c;只要 Tab标签不关闭&#xff0c;对应的页面就会被缓存&#x…...

C++STL剖析(四)—— stack和queue的概念和使用

文章目录1. stack的介绍2. stack的构造3. stack的使用&#x1f351; push&#x1f351; top&#x1f351; pop&#x1f351; empty&#x1f351; size&#x1f351; swap&#x1f351; emplace4. queue的介绍5. queue的构造6. queue的使用&#x1f351; push&#x1f351; size…...

流浪地球 | 建筑人是如何看待小破球里的黑科技的?

大家好&#xff0c;这里是建模助手。 想问问大家今年贺岁档&#xff0c;都跟上没有&#xff0c;今天请允许我蹭一下热点表达一下作为一个科幻迷的爱国之情。 抛开大刘的想象力、各种硬核科技&以及大国情怀不提&#xff0c;破球2中的传承还是让小编很受感动&#xff0c;无…...

软中断在bottom-half中调用

https://www.bilibili.com/read/cv20785285/简介软中断可以在两个位置得到机会执行&#xff1a;硬中断返回前 irq_exit中断下半部 Bottom-half Enable后情景分析情景1spin_unlock_bh__raw_spin_unlock_bh__local_bh_enable_ip 打开Bottom-half&#xff0c;并让softirq有机会…...

GEE遥感云大数据在林业中的应用

近年来遥感技术得到了突飞猛进的发展&#xff0c;航天、航空、临近空间等多遥感平台不断增加&#xff0c;数据的空间、时间、光谱分辨率不断提高&#xff0c;数据量猛增&#xff0c;遥感数据已经越来越具有大数据特征。遥感大数据的出现为相关研究提供了前所未有的机遇&#xf…...

Apollo架构篇 - 客户端架构

前言 本文基于 Apollo 1.8.0 版本展开分析。 客户端 使用 Apollo 支持 API 方式和 Spring 整合两种方式。 API 方式 API 方式是最简单、高效使用使用 Apollo 配置的方式&#xff0c;不依赖 Spring 框架即可使用。 获取命名空间的配置 // 1、获取默认的命名空间的配置 C…...

JVM调优最全面的成长 :参数详解+垃圾算法+示例展示+类文件到源码+面试问题

目录1.优秀的Java开发者1.1 什么是Java&#xff1f;1.2 编程语言1.3 计算机[硬件]能够懂的语言1.3.1 计算机发展史1.3.2 计算机体系结构1.3.3 计算机处理数据过程1.3.4 机器语言1.3.5 不同厂商的CPU1.3.6 操作系统1.3.7 汇编语言1.3.8 高级语言1.3.9 编译型和解释型1.3.9.1 编译…...

linux驱动常用函数

以下为一些常见用户态函数在内核中的替代&#xff0c;包括头文件和函数声明&#xff1a;1、动态申请内存&#xff1a;linux/vmalloc.hvoid *vmalloc(unsigned long size);void vfree(const void *addr);2、字符串操作&#xff1a;linux/string.hvoid * memset(void *,int,__ker…...

Flowable进阶学习(九)数据对象DataObject、租户Tenant、接收任务ReceiveTask

文章目录一、数据对象DataObject二、租户 Tenant三、接收任务 ReceiveTask案例一、数据对象DataObject DataObject可以⽤来定义⼀些流程的全局属性。 绘制流程图&#xff0c;并配置数据对象&#xff08;不需要选择任意节点&#xff09; 2. 编码与测试 /*** 部署流程*/ Test…...

C语言实现五子棋(n子棋)

五子棋的历史背景&#xff1a; 五子棋起源于中国&#xff0c;是全国智力运动会竞技项目之一&#xff0c;是一种两人对弈的纯策略型棋类游戏。双方分别使用黑白两色的棋子&#xff0c;下在棋盘直线与横线的交叉点上&#xff0c;先形成五子连珠者获胜。五子棋容易上手&#xff0c…...

OpenStack云平台搭建(2) | 安装Keystone

目录 1、登录数据库配置 2、数据库导入Keystone表 3、配置http服务 4、创建域、用户 5、创建脚本 Keystone&#xff08;OpenStack Identity Service&#xff09;是 OpenStack 框架中负责管理身份验证、服务访问规则和服务令牌功能的组件。下面我们进行Keystone的安装部署 1…...

基于javaFX的固定资产管理系统

1. 总体设计 本系统分为登录模块、资产管理模块、资产登记模块和信息展示模块共四个模块。 登录模块的主要功能是&#xff1a;管理员通过登录模块登录本系统&#xff1b; 资产管理模块的主要功能有&#xff1a;修改、删除系统中的固定资产&#xff1b; 在资产登记模块中&#…...

板子登录和挂载问题记录

ubuntu登录板子问题 ssh登录ssh 10.1.3.15&#xff0c;显示No route to host 则尝试在板子上ping 本机ip 试一下 挂载 本地机器vim /etc/export编辑此内容并保存 /exports_0209/tda4_build *(rw,no_root_squash,nohide,insecure,no_subtree_check,async)1.挂载nfs方法 mou…...

销售网站建设考核指标/如何让百度收录自己的网站信息

TIDB 数据库集群 一、TiDB数据介绍 1.1、TiDB数据简介 TiDB 是 PingCAP 公司设计的开源分布式 HTAP (Hybrid Transactional and Analytical Processing) 数据库&#xff0c;结合了传统的 RDBMS 和 NoSQL 的最佳特性。TiDB 兼容 MySQL&#xff0c;支持无限的水平扩展&#xff0c…...

杭州百度网站建设/手机刷网站排名软件

1、jenkins服务器和各节点服务器之间&#xff0c;要配置基于密钥的登录 (本实例基于www用户)(省略)2、创建相应的目录&#xff0c;并授权属主属组为www用户/deploy/tmp 临时目录/deploy/tar 存放打包后的目录/opt/wwwroot 远程服务器目录/web/ 网站目录3、配置jenkins![](https…...

威海好的网站建设公司哪家好/公众号推广费用一般多少

测试一口吧! 运行代码转载于:https://www.cnblogs.com/a6948076/p/9909800.html...

制作一个网站的流程/seo百度快速排名

人工智能和深度学习发展趋势尽管当今流行的数字转换工具扩展了分析&#xff0c;社交&#xff0c;物联网和移动技术所提供的可能性&#xff0c;但是还有一个不可忽视的潜在因素。 如果企业的基础架构能够跟上步伐&#xff0c;那么企业就只能进行足够快的转型。 那么&#xff0c…...

南京专业网站开发团队/长沙官网seo推广

从Active Directory获取大量对象时应特别注意&#xff0c;一不小心&#xff0c;就会掉入性能瓶颈甚至引起内存泄漏。本文提供了一个关于.NET访问Active Directory的优化例子。 1.获取对象的属性值 DirectoryEntry.Properties 获取一个DirectoryEntry对象后&#xff0c;我们就开…...

哪个网站能看到学做标书/农业推广

Windows Ps菜单&#xff1a;编辑/首选项macOS Ps菜单&#xff1a;Photoshop/首选项快捷键&#xff1a;Ctrl/Cmd K对 Ps 的首选项 Preferences进行设置&#xff0c;可以提高修图与设计效率。下面是一些首选项设置的建议&#xff0c;供参考。常规GeneralHUD 拾色器 HUD Picker建…...