• h2database,一个内存数据库解决方案


    这不是一个新东西,但是它却是一个被严重低估的东西.
    为了让它不再被继续低估,我打算为推广和宣传它贡献出自己的一点点力量.

    =================================

    先来个简介.
    h2database 官方网站
    http://www.h2database.com/

    这个是一个 java编写的轻量级数据库.

    类似的轻量级数据库实际上有很多, 例如java自带的derby,还有历史悠久的hsqldb,postgreSQL,sqlite...
    和这些前辈比起来似乎他的来头小了一点.但是它绝对绝对绝对足够出色足够优秀.

    我第一次接触他大概是在两年前, 使用它之后我就几乎再也没用过其他轻量级数据库了.(之前用过hsqldb mysql postgresql)

    它完全开源, 小巧, 纯java编写,只有一个不到1M的jar(已经包含了jdbc驱动) , 不依赖任何第三方的组件.
    支持多种数据库模式:  c/s模式(相当于一个轻量级的mysql), 内存模式(相当于一个轻量级的内存数据库), 嵌入式模式.
    支持多种连接方式. 支持hibernate.
    拥有详尽出色的文档.这是我见过的最出色的开源软件文档之一.完全可以作为一本学习数据库的教材来使用.

    由于全部由java编写,所以可以用java对它进行全面的控制,例如 启动/停止服务, 管理帐号等等.
    当然,如果它不与java的程序配合使用,那么优势就减少很多,因为毕竟还需要jdk支持.

    =================================

    和其他轻量级数据库的特性对比:




    它还有如下主要特性:


    更多的详细说明见:  http://www.h2database.com/html/features.html
     
    下面是性能对比



    (此处只是c/s模式下的对比, 这里 http://www.h2database.com/html/performance.html  还有更多的对比):


    当然,它也有缺点,但是它的缺点往往只有在把它应用到它并不适合的场景(高并发 大数据量)时才会体现的比较明显.

    =================================

    H2DB出现也有很长时间了, 但是名气一直不大,我觉得并不是他的品质造成的,而是因为它的背后缺少大型的商业的组织支持.

    近期我也正打算写一些H2DB的文章,来为h2db的普及做一些贡献,敬请期待.

    JE上以前也有一些介绍性文章
    大家可以自行搜索一下
    在"介绍""概述"方面 显然其他作者比我更擅长


    ==================================
    补充
    ==================================


    针对robbin 的回复补充一个现实中的一个场景:

    以前给某公司做BSS, 遇到了下面的情况.

    系统的菜单 (树状结构)全部菜单项有2000多条, 菜单主要用在系统的上边导航 还有左边的菜单树
    地市/分公司列表 这个不多 (毕竟联通占有率不高) 但是也有3位数了
    这个应用场景极其的多, 很多操作又要用到, 相当于一个字典表
    地市分公司部门列表 全部数据2000条左右,也相当于字典表

    以上四种数据控制的"最小粒度"都是基于"人"的, 也就是说每个操作员操作系统时看到的都是不一样的.

    这个系统同时在线人数5000多.

    对于当时的运行环境来说,  web服务器是有N多台 而且很好很强大, 但是数据库并没有那么多.(对数据库做群集?太疯狂了吧).

    这种类似字典表的东西通常都是取出来放到缓存里,缓存可以借助ehcache之类的组件来实现.以此来减少对数据库的操作.

    但是对于上面的情况, 显然是做不到的, 因为 判断一个数据项,是否对于当前的操作员可见,要进行复杂的判断,而且要对数据项做全遍历.  而如果不缓存,每次都从数据库去取 ,这么做同样是不可取的.

    所以,最好的方法就是  用运行在web服务器上的"内存数据库"来实现一个支持 sql的 高级缓存.

    ===================================

    再拿游戏举下例子,游戏的存档就是一个小型的数据库,如果有嵌入式数据库帮忙开发游戏的话,就不用为存档系统大动干戈了,
    还有, NBA LIVE系列游戏里面包含了大量的球队和球员历史信息,这些信息就是被存在一个嵌入式数据库里的.如果没有嵌入式数据库,那么游戏中检索这些球员的数据将是多么繁琐的事情啊.
    同时嵌入式数据库还可以用来加密. 把软件运行时需要的资源(数据 文件 图片等)放到嵌入式数据库里, 运行时"查询出".
    免得自己再写一套机密机制.

    ===================================

    以上说了这么多, 只是想说明一下, 嵌入式内存数据库其实用处真的蛮大的. 而且用法很灵活,
    套用一句俗话"它是否有用并不取决于它自身 而是取决于我们的想象力"
  • 相关阅读:
    Combox小问题
    数据库登录名,用户,角色以及权限分配
    UDP初识
    AJax 无刷新构建DataTable
    批量修改数据库构架SQL
    Jquery Ajax
    Linq中使用Group By
    对象的消息模型
    P2P网络技术概览与实现原理
    ajax(1)
  • 原文地址:https://www.cnblogs.com/interdrp/p/1541860.html
Copyright © 2020-2023  润新知