- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
键值对数据库综述与典型数据库介绍
一、键值数据库概述
键值数据库是一种非关系数据库,它使用简单的键值方法来存储数据。键值数据库将数据存储为键值对集合,其中键作为唯一标识符。键和值都可以是从简单对象到复杂复合对象的任何内容。键值数据库是高度可分区的,并且允许以其他类型的数据库无法实现的规模进行水平扩展。
键值对数据模型实际上是一个映射,即是查找每条数据地址的唯一关键字,是该数据实际存储的内容。例如键值对:(“”,“张三”),其:“”是该数据的唯一入口,而:“张三”是该数据实际存储的内容 数据模型典型的是采用哈希函数实现关键字到值的映射,查询时,基于 的值直接定位到数据所在的点,实现快速查询,并支持大数据量和高并发查询。
二、基本原理
从的角度来看,键值数据库是最简单的数据库。客户端可以根据键查询值,设置键所对应的值,或从数据库中删除键。“值”只是数据库存储的一块数据而已,它并不关心也无需知道其中的内容;应用程序负责理解所存数据的含义。由于键值数据库总是通过主键访问,所以它们一般性能较高,且易于扩展。基本上所有的编程语言都带有应用在内存中的键值对存储。的映射容器( )和的以及的字典类型都是键值对存储。键值对存储通常都有如下接口:
( ): 获取之前存储于某标示符“”之下的一些数据,或者“”下没有数据时报错。
( , ): 将“”存储到存储空间中某标示符“”下,使得我们可以通过调用相同的“”来访问它。如果“”下已经有了一些数据,旧的数据将被替换。
( ): 删除存储在“”下的数据。
三、基本特性
键值数据库具有以下几个特性:
容错性
可扩展性
有效性
四、读写方式
分析已有 数据库,其读写方式可分为面向磁盘的读写方式和面向内存的读写方式两种.后者适合于不要求存储海量的数据但需要对特定的数据进行高速并发访问的场景.采用哪一种读写方式,通常由数据量的大小和对访问速度的要求决定的。
) 面向磁盘的读写方式
通常情况下 系统中都存储着海量的数据,且无法全部维持在内存中,所以一般都采用面向磁盘的读写方式,下图描述了 系统中采用的典型的面向磁盘读写的一般过程。
图 面向磁盘的读写过程
通常,当写入数据时,数据首先会被写到一个内存结构中,系统返回写入成功.当内存中的数据达到指定大小或存放超过指定时限时,会被批量写入磁盘.当需要读取数据时,首先访问内存结构,如果未命中则需要访问磁盘上的实例化文件.当系统发生意外宕机时,内存结构中的数据将丢失,因此,一般采用日志的方式来帮助进行数据恢复.为了进一步提高写入效率和并发能力,许多系统都采用了 的方式,即将修改和删除操作都追加写到文件末尾,而读数据时利用时间戳过滤掉旧信息,返回给用户最新版本的数据.因此,数据库需要进行定期的数据合并,将过期的冗余数据删除。
)面向内存的读写方式
内存数据库将所有数据存放在内存中。每次访问记录时,无需将数据从磁盘读到内存中,避免了磁盘操作造成的延迟。在几十年前,由于内存容量的限制,在数据库中,内存只能充当磁盘的缓存。但随着存储技术的迅猛发展,单台机器的内存容量不断增长。目前,高端的服务器已经能提供几太字节的内存容量。这使得将所有数据存在内存中成为可能。磁盘读写操作不再是性能瓶颈后,数据库系统由 受限()转向 受限()。
五、键值数据库的优缺点
存储非常适合不涉及过多数据关系业务关系的业务数据,同时能有效减少读写磁盘的次数,比数据库存储拥有更好的读写性能
由于需要根据键值查询,所以可以根据时间戳等数据库之外的值来生成键名,所以键值数据库非常适合保存会话(会话为主键)、购物车数据、用户配置等信息。还可以使用属性指定关键字的过期时间,这对会话或购物车对象特别有用。
这同时表示像那样用语句或者通过任何形式的过滤来请求数据中的一部分是无法做到的。如果你不知道去哪找,你必须遍历所有的键,获取它们对应的值,应用某种你需要的过滤,然后保留你想要的东西。这将会需要大量的运算,也即表示只有当键已知的时候才能体现出最佳性能,否则键值对存储将无法胜任
不像关系型数据库,键值对存储不需要了解值中的数据,也没有像或者中那样的任何结构。它不关心键值对里的值,可以是二进制块、文本、、等。
六、典型的键值数据库
键值数据库主要可以分为两种:面向内存的存储和面向磁盘的存储,前者的典型应用是和,后者是和。
(一)简介
是一个开源的使用 语言编写、支持网络、可基于内存亦可持久化的日志型、数据库,并提供多种语言的。 是一个开源(许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。 它支持多种类型的数据结构,如 字符串(), 散列(), 列表(), 集合(), 有序集合( ) 与范围查询, , 和 地理空间() 索引半径查询。目前由主持开发工作。
它具有以下几个特点:
使用编写,运行异
您可能关注的文档
最近下载
- 2025年张家口辅警协警招聘考试真题完美版.docx VIP
- 辽宁省辽阳市2025届高三下学期一模生物试卷含答案.docx VIP
- 2025秋统编版(2024)道德与法治二年级上册第三单元我的家乡美《第12课 家乡新变化》教学设计 .pdf
- 地区调整系数图册-国土资源调查预算(地质调查部分).pdf VIP
- 预见性护理及早期风险识别.pptx VIP
- 2025年嘉峪关辅警协警招聘考试真题完美版.docx VIP
- 《分析人类活动对生态环境的影响 学情分析》.docx VIP
- DZ/T 0215-2002 煤、泥炭地质勘查规范.pdf VIP
- 2021.6.19 西药二高端班测试卷.docx VIP
- 从惠民保全国生态预判城市定制型商业医疗保险未来发展路径——《城市定制型商业医疗保险(惠民保)知识图谱》解读.pdf VIP
原创力文档


文档评论(0)