EagleBear2002 的博客

这里必须根绝一切犹豫,这里任何怯懦都无济于事

《NoSQL 精粹》第八章-键值数据库

何谓键值数据库

键值数据库(key-value store)是一张简单的哈希表(hash table),主要用在所有数据库访问均通过主键(primary key)来操作的情况下。

键值数据库特性

适用案例

存放会话信息

通常来说,每一次网络会话都是唯一的,所以分配给它们的 sessionid 值也各不相同。

如果应用程序原来要把 sessionid 存在磁盘上或关系型数据库中,那么将其迁移到键值数据库之后,会获益良多

  1. 因为全部会话内容都可以用一条 PUT 请求来存放,而且只需一条 GET 请求就能取得。
  2. 由于会话中的所有信息都放在一个对象中,所以这种单请求操作(single-request operation) 很迅速。

用户配置信息

用户配置信息,几乎每位用户都有 userId、username 或其他独特的属性,而且其配置信息也各自独立,诸如语言、颜色、时区、访问过的产品等。

这些内容可全部放在一个对象里,以便只用一次 GET 操作即获取某位用户的全部配置信息。

同理,产品信息也可如此存放。

购物车数据

购物车数据,电子商务网站的用户都与其购物车相绑定。

由于购物车的内容要在不同时间、不同浏览器、不同电脑、不同会话中保持一致,所以可把购物信息放在 value 属性中,并将其绑定到 userid 这个键名上。

不适用场合

数据间关系

如果要在不同数据集之间建立关系,或是将不同的关键字集合联系起来,那么即便某些键值数据库提供了链接遍历等功能,它们也不是最佳选择。

含有多项操作的事务

如果在保存多个键值对时,其中有一个关键字出错,而又需要复原或回滚其余操作,那么键值数据库就不是最好的解决方案。

查询数据

如果要根据键值对的某部分值来搜寻关键字,那么键值数据库就不是很理想了。我们无法直接检视键值数据库中的值,除非使用某些检索引擎(indexing engine)。

操作关键字集合

由于键值数据库一次只能操作一个键,所以它无法同时操作多个关键字。假如需要操作多个关键字,那么最好在客户端处理此问题。