本资源由 伯乐在线 - 刘立华 整理

H2是一个开源的内存数据库。Java编写、快速、小巧(1.5MB jar包)还提供了Web控制台管理数据库内容。

主要功能

  • 非常快速的数据库引擎。
  • 开源。
  • Java编写。
  • 支持标准SQL、JDBC API。
  • 支持嵌入式模式、服务器模式和集群。
  • 强大的安全功能。
  • 支持PostgreSQL的ODBC驱动。
  • 多版本并发。

附加功能

  • 支持基于硬盘或内存数据库和表、只读数据库、临时表。
  • 支持事务(read committed),两步提交机制(2-phase-commit)。
  • 多个连接,表级锁。
  • 基于成本的优化、复杂查询采用遗传算法、零管理。
  • 支持可滚动和可更新的结果集、大结果集、外部结果排序、函数可以返回结果集。
  • 加密的数据库(AES)、SHA-256加密的密码、加密功能、SSL。

SQL支持

  • 支持多schema、information schema(Support for multiple schemas, information schema)。
  • 参照完整性/使用级联外键约束、check约束。
  • 内连接和外链接、子查询、只读视图和内嵌视图。
  • 触发器及Java函数/存储过程。
  • 很多内置功能,包括XML和无损压缩。
  • 广泛的数据类型,包括大对象(BLOB/CLOB)和数组。
  • 队列和自增长的列、计算列(可用于基于索引的功能)。
  • 支持ORDER BY、GROUP BY、HAVING、UNION、LIMIT、TOP。
  • 支持排序规则,包括ICU4J库。
  • 支持用户和角色。
  • 兼容模式支持IBM DB2、Apache Derby、HSQLDB、MS SQL Server、MySQL、Oracle、和PostgreSQL等。

安全功能

  • 包括对SQL注入问题的解决方案。
  • 使用SHA-256和盐(SHA-256 and salt)认证用户密码。
  • 对于服务器模式的连接,用户密码从不会以纯文本格式通过网络传输。
  • 所有数据库文件(包括用于备份数据的脚本文件)可使用AES-128算法加密。
  • 远程JDBC驱动支持通过TLS的TCP/IP连接。
  • 内置的web服务器支持通过TLS连接。
  • 密码使用char数组发送到数据库,而不是String。

其它功能和工具

  • 体积小巧(小于1.5MB),低内存需求。
  • 多种索引类型(b-tree、tree、hash)。
  • 支持多维索引。
  • 支持CSV文件。
  • 支持链表,及一个内置的虚拟“range”表。
  • 支持EXPLAIN PLAN声明;复杂的跟踪选项。
  • 数据库关闭可以延迟或者禁用以提高性能。
  • 自带基于web的控制台应用(已译成多国语言)。
  • 数据库可以生成SQL脚本文件。
  • 包含一个恢复工具,可以转储数据库内容。
  • 支持变量(例如计算运行总和)。
  • 自动重新编译预处理语句。
  • 使用少量数据库文件。
  • 为每一条记录和日志条目使用校验和以保证数据完整性。
  • 经过充分测试(高覆盖率、随机压力测试)。

连接模式简介

支持以下三种模式:

  • 嵌入式模式(使用JDBC的本地连接)。
  • 服务器模式(使用JDBC或ODBC的通过TCP/IP的远程连接)。
  • 混合模式(本地和远程连接同时存在)。

嵌入式模式

在嵌入式模式下,应用程序使用和JDBC相同的JVM打开数据库。这是最快、最简单的连接方式。缺点是数据库任何时候只在一个虚拟机中打开。同时支持持久化和在内存中存储数据。没有同时打开数据库的数量限制,没有连接数限制。

服务器模式

当使用服务器模式时(也称作远程模式或者客户端/服务端模式),应用程序使用 JDBC或ODBC API以远程方式打开数据库。数据库服务器需要在相同或者另外的虚拟机,或者干脆另外一台计算机启动。 很多应用程序可以同时通过连接到这台服务器连接同一个数据库。在内部,该服务器进程以嵌入式模式打开多个数据库。 由于所有数据通过TCP/IP传输,服务器模式要比嵌入式模式慢一些。同时支持持久化和在内存中存储数据。每台服务器没有同时打开数据库的数量限制,没有 连接数限制。

混合模式

混合模式是嵌入式模式和服务器模式的组合。第一个应用程序在嵌入式模式中连接到数据 库,但也启动了一个数据库服务器,这样其他应用程序(运行在不同进程或虚拟机中)可以同时访问数据。本地连接像嵌入式模式一样快速,远程连接稍慢。 数据库服务器可以通过API,或者自动化(自动混合模式)启停。当使用自动混合模式时,所有要连接数据库的客户端可使用完全相同的URL。

开发资源

官方网站:http://www.h2database.com/
开源地址:https://github.com/h2database/h2database

from:http://hao.jobbole.com/h2-2/

H2:开源内存数据库引擎的更多相关文章

  1. Camunda开源流程引擎快速入门——Hello World

    市场上比较有名的开源流程引擎有osworkflow.jbpm.activiti.flowable.camunda.由于jbpm.activiti.flowable这几个流程引擎出现的比较早,国内人用的 ...

  2. 你需要知道的MySQL开源存储引擎TokuDB

    在四月份的Percona Live MySQL会议上, TokuDB庆祝自己成为开源存储引擎整一周年.我现在仍能记得一年前它刚创建时的官方声明与对它的期望.当时的情况非常有意思,因为它拥有帮助MySQ ...

  3. 开源分布式计算引擎 & 开源搜索引擎 Iveely 0.5.0 为大数据而生

    Iveely Computing 产生背景 08年的时候,我开始接触搜索引擎,当时遇到的第一个难题就是大数据实时并发处理,当时实验室的机器我们可以随便用,至少二三十台机器,可以,却没有程序可以将这些机 ...

  4. Java三大主流开源工作流引擎技术分析

    首先,这个评论是我从网上,书中,搜索和整理出来的,也许有技术点上的错误点,也许理解没那么深入.但是我是秉着学习的态度加以评论,学习,希望对大家有用,进入正题! 三大主流工作流引擎:Shark,oswo ...

  5. 《Genesis-3D开源游戏引擎--横版格斗游戏制作教程08:虚拟键盘实现》--本系列完结

    8.虚拟键盘实现 概述: 硬键盘就是物理键盘,平时敲的那种.软键盘是虚拟的键盘,不是在键盘上,而是在"屏幕"上.虚拟按键就是虚拟键盘的一部分,根据功能需求,提供部分按键效果的UI可 ...

  6. 《Genesis-3D开源游戏引擎完整实例教程-2D射击游戏篇:简介及目录》(附上完整工程文件)

    G-3D引擎2D射击类游戏制作教程 游戏类型: 打飞机游戏属于射击类游戏中的一种,可以划分为卷轴射击类游戏. 视觉表现类型为:2D 框架简介: Genesis-3D引擎不仅为开发者提供一个3D游戏制作 ...

  7. 《Genesis-3D开源游戏引擎-FQA常见问题解答》2014年01月10号版本

    1.Genesis-3D开源游戏引擎主要面向哪些用户人群?有限制吗? 1.我们的引擎没有限制,只要您想了解和使用我们的引擎,就可以加入Genesis-3D的大家庭.2.我们的主要用户群是各个相关的企业 ...

  8. 《Genesis-3D开源游戏引擎完整实例教程-跑酷游戏篇:简介及目录》(附上完整工程文件)

    跑酷游戏制作 游戏类型: 此游戏Demo,为跑酷类游戏. 框架简介: 游戏通常由程序代码和资源组成.如果说模型.贴图.声音之类的可以给游戏环境提供一个物理描述和设置,那么脚本和代码块会给游戏赋予生命, ...

  9. Genesis-3D开源游戏引擎简介!

    Genesis-3D由搜狐畅游公司超百人引擎研发团队历时数年耗费巨资自主研发,是国内外首款商业开源的3D游戏引擎平台.它包括跨平台渲染引擎.2D引擎.物理引擎.音效系统.粒子系统.动画系统.服务器引擎 ...

随机推荐

  1. 兼容到ie10的js文件导出、下载到本地

    话不多说,上代码: try { let reader = new FileReader(); let blob = new Blob([res.data], { type: 'application/ ...

  2. Java 分布式系统 实现session共享

    当然业界已经有很多成熟的解决方案,我罗列如下: 1.服务器实现的session复制或session共享,这类型的共享session是和服务器紧密相关的,比如webSphere或JBOSS在搭建集群时候 ...

  3. QT5 - 数据库、QMYSQL driver not loaded

    第一步.先在“.pro”的入口文件里加入以下两行代码: QT += sql SOURCES += main.cpp 第二步.在“main.cpp”文件中连接数据库并判断是否连接成功 1.QPSQL连接 ...

  4. 洛谷P1533 可怜的狗狗 [平衡树,FHQ_Treap]

    题目传送门 可怜的狗狗 题目背景 小卡由于公务需要出差,将新家中的狗狗们托付给朋友嘉嘉,但是嘉嘉是一个很懒的人,他才没那么多时间帮小卡喂狗狗. 题目描述 小卡家有N只狗,由于品种.年龄不同,每一只狗都 ...

  5. 第一次使用Git上传本地项目到github上

    对于程序原来说都听说过GitHub,GitHub有许多开源的的项目和一些前沿的技术.因为自己在刚刚开始使用Git把自己写的一些小dome放到GitHub上遇到许多的坑,这么长时间过去了,想对第一次使用 ...

  6. React Native Android启动白屏的一种解决方案下

    实现思路 思路大流程: 1.APP启动的时候控制ReactActivity从而显示启动屏. 2.编写原生模块,提供一个关闭启动屏的公共接口. 3.在js的适当位置(一般是程序初始化工作完成后)调用上述 ...

  7. Outdated Kotlin Runtime

    你的 kotlin 运行时版本 在 1.1.2库中 是 1.1.2 然而插件版本是 1.1.4 . 运行时库 应该被更新,避免兼容问题. Outdated Kotlin Runtime Your ve ...

  8. BSGS算法学习

    嗯哼大步小步法. 一个非常暴力的想法. 注意到如果设C = ⌈√P⌉,那么任何一个数都可以写 成a1 * C + b1的形式,其中a1, b1 都< C. 那么预处理出A^i*C的值.然后在询问 ...

  9. [BZOJ3757]苹果树(树上莫队)

    树上莫队共有三种写法: 1.按DFS序列分块,和普通莫队类似.常数大,不会被卡. 2.按块状树的方式分块.常数小,会被菊花图卡到O(n). 3.按[BZOJ1086]王室联邦的方式分块.常数小,不会被 ...

  10. BZOJ.2462.[BeiJing2011]矩阵模板(二维Hash)

    题目链接 序列上的Hash和前缀和差不多,二维Hash也和二维前缀和差不多了. 预处理大矩阵所有r*c的小矩阵hash值,再对询问的矩阵Hash. 类比于序列上\(s[r]-s[l-1]*pow[r- ...