轻量级数据库比较:SQLite、H2 和 MySQL Embedded

红薯 发布于 2012/07/09 10:19
阅读 43K+
收藏 50

对 PHP程序员来说,SQLite可以快速的搭建数据库开发环境,提供轻松、自容器、无配置、无独立服务的数据库环境,所有数据保存在一个文件里。当使用 MySQL 作为最终生产平台时,SQLite 是不可替代的开发环境解决方案。但真的没有其他兼容性更好的选择了吗?好吧,仅举几个原因:MySQL的兼容性和支持哈希索引,还不止这些!

当我们寻找 SQLite 的替代方案时,有两个可选,分别是 H2 和 MySQL Embeded 版本。我关注的是可像 SQLite 一样方便使用,但又必须兼容 MySQL。

下面我们对三个数据库进行简单的比较:

比较项目
SQLite H2 database engine MySQL Embedded
Footprint 350KiB ~1MB <2MB
授权协议
Public domain Dual: Modified MPL 1.1 / EPL 1.0 (commercial friendly) GPL 2.0 (only commercial friendly if not redistributed)
自容器
单文件
无服务器
服务器模式
零配置
事物处理
索引 ✔ (B-tree, R-tree, full-text) ✔ (B-tree, tree, hash, full-text) ✔ (B-tree, R-tree, hash, full-text)
MySQL 兼容性
✔ (but not 100%)
兼容其他数据库 ✔ MySQL, PostgreSQL, Oracle, MSSQL, DB2, HSQLDB and Derby
加密
内存中数据库
✔ (MEMORY storage engine)

 

看似 H2 管理最简单,因此我在 PHP 下体验了 H2 后发现的一些限制:Quercus 的 MySQL 驱动无法和 H2 的 MySQL 兼容模式良好的工作,我必须使用 Quercus 的 PDO 驱动来替代。

MySQL Embedded 则是 100% 兼容 MySQL,我还没有开始测试。但也有一些不确定的问题,我不清楚是否可以分发包含 MySQL Embedded 的应用程序,这可能需要购买商业授权。

英文原文OSCHINA原创翻译

加载中
1
李惟
李惟
说来说去,我还是觉得 SQLite 好
1
天上白云
天上白云
SQLite做为客户端应该很给力,但如果做为服务端应用,在并发处理上会伤感情的
m
mei
sqlite3是作为嵌入式开发使用,sqlite4是向服务器进军的,lsm用于大数据出来。
0
lanx
lanx
sqlite还可以用于手机浏览器端
0
林宝基
林宝基
SQLITE 在IPHONE 上性能不错。。推荐推荐
0
景愿
景愿
MySQL好尴尬,上不上,下不下
0
Codin
Codin
我现在发现数据库的性能不在数据库软件上,而在开发人员对数据库的理解力以及SQL的编写上。今天还被大大训斥,说宁可多开几次数据库连接,也不要使用左关联。现在的项目使用Hibernate,但大大不允许使用关联关系,发现自己好尴尬。
j
jass
为什么宁可多连接几次,也不用左关联?
mark35
mark35
用的mysql?
0
lilihao102
lilihao102
SQLITE是支持加密机制的。
0
东厢里的一只喵
东厢里的一只喵
 通篇h2 ad 判定完毕。
0
faluo888
faluo888
轻量数据库,最喜欢SQLite了。不为别的,简单小巧方便快速~!这就足够了。
0
ValueError
ValueError
SQLite 的 UDF 非常暴力
m
mei
mysql 也有的,现在主流的数据库基本都具备这个功能。
OSCHINA
登录后可查看更多优质内容
返回顶部
顶部