何谓键值数据库
键值数据库(key-value store)是一张简单的哈希表(hash table),主要用在所有数据库访问均通过主键(primary key)来操作的情况下。
键值数据库特性
适用案例
存放会话信息
通常来说,每一次网络会话都是唯一的,所以分配给它们的 sessionid 值也各不相同。
如果应用程序原来要把 sessionid 存在磁盘上或关系型数据库中,那么将其迁移到键值数据库之后,会获益良多
- 因为全部会话内容都可以用一条 PUT 请求来存放,而且只需一条 GET 请求就能取得。
- 由于会话中的所有信息都放在一个对象中,所以这种单请求操作(single-request operation) 很迅速。
用户配置信息
用户配置信息,几乎每位用户都有 userId、username 或其他独特的属性,而且其配置信息也各自独立,诸如语言、颜色、时区、访问过的产品等。
这些内容可全部放在一个对象里,以便只用一次 GET 操作即获取某位用户的全部配置信息。
同理,产品信息也可如此存放。
购物车数据
购物车数据,电子商务网站的用户都与其购物车相绑定。
由于购物车的内容要在不同时间、不同浏览器、不同电脑、不同会话中保持一致,所以可把购物信息放在 value 属性中,并将其绑定到 userid 这个键名上。
不适用场合
数据间关系
如果要在不同数据集之间建立关系,或是将不同的关键字集合联系起来,那么即便某些键值数据库提供了链接遍历等功能,它们也不是最佳选择。
含有多项操作的事务
如果在保存多个键值对时,其中有一个关键字出错,而又需要复原或回滚其余操作,那么键值数据库就不是最好的解决方案。
查询数据
如果要根据键值对的某部分值来搜寻关键字,那么键值数据库就不是很理想了。我们无法直接检视键值数据库中的值,除非使用某些检索引擎(indexing engine)。
操作关键字集合
由于键值数据库一次只能操作一个键,所以它无法同时操作多个关键字。假如需要操作多个关键字,那么最好在客户端处理此问题。