之前paul graham向我们展示了一个有趣的比较各种编程语言的方法:阐述各种编程语言都是用来解决什么问题的。我发现这种方法放在数据库上同样好用:
oracle: 我们需要企业级数据库。
mysql: oracle不开源。
postgresql: mysql的功能不够多。
sqlite: 你可以把我嵌入到任何地方。这样,4种数据库够大家用了。
mongodb: 为什么我们要用join和模式(schema)?
couchdb: 为什么我们要有集合(collection)?
redis: 为什么我们要面向文档?
memcached: 为什么我们要用硬盘?
neo4j: sql缺乏足够的关系。
bigtable: mongodb的对web的扩展性不管好。
hbase: bigtable不开源。
cassandra: bigtable不是facebook开发的。
riak: cassandra不是用erlang语言编写的。
orientdb: 让我们把所有东西都放到同一个数据库里!
bitscn.com
