存储功能概述计划
Berkeley DB所管理数据的逻辑组织单位是若干个独立的或有一定关系的数据库
(database),每个数据库由若干记录组成,这些记录全都被表示成(key,value)的形式,如果把一组相关的(key,value)对也看作一个表的话,那么每一个数据库只允许存放一个table,这一点不同于一般的关系数据库。实际上,在Berkeley DB中所提到的“数据库”,相当于一般关系数据库系统中的表;而“key/data”对相当于关系数据库系统中的行(rows);Berkeley DB不提供关系数据库中列直接访问的功能,而是在“key/data”对中的data项中通过实际应用来封装字段(列)。
在物理组织上,每一个数据库在创建的时候可以由应用程序根据其数据特点来选择一种合适的存储结构。可供选择的四种文件存储结构分别是:哈希文件、B树、定长记录(队列)和变长记录(基于记录号的简单存储方式)。一个物理的文件中可以只存放一个单独的数据库,也可以存放若干相关或不相关的数据库,而且这些数据库可以分别采用除队列之外任意不同的组织方式,以队列组织的数据库只能单独存放于一个文件,不能同其他存储类型混合存放。一个文件除了受最大文件长度和存储空间的约束之外,理论上可以存储任意多个数据库。因此系统定位一个数据库通常需要两个参数――“文件名”和“数据库名”,这也是Berkeley DB不同于一般关系数据库的地方。
Berkeley DB存储系统为应用程序提供了一系列的接口函数,用于对数据库的管理和操作。其中包括:
(1)数据库的创建、打开、关闭、删除、重命名等,以及对数据的检索和增删改操作;
(2)提供一些附加的功能,例如读取数据库状态信息、读取所在文件的信息、读取所在数据库环境的信息、清空数据库的内容、数据库的同步备份、版本升级、提示出错信息等等;
(3)系统还提供了游标机制,用于存取和访问成组的数据,以及对两个或多个相关数据库进行关联和等值连接操作;
(4)系统还给出了一些接口函数用于对存取策略进行优化配置,比如应用程序可以自己设置B树的排序比较函数、每页中存放key的最少数目,哈希桶的填充因子、哈希函数、哈希表最大长度,队列的最大长度,数据库存放的字节顺序,底层存储页的大小,内存分配函数,高速缓存的大小,定长记录的大小和填充位,变长记录所用的分隔符等等。
起身准备和陈先生一起与抢劫嫌疑人搏斗。对方见状 查看本文来源
如何补气避免流失铜仁白癜风医院哪家医院好
南昌哪家医院治白癜风好
- 存储巨头们,拼成什么?
- 公职考试也看“家庭背景”,这3类人很有优势,考上机会很大!
- 从“狗玩的”到“人玩的”:飞盘在年轻人当中爆火,却离商业化很远
- 竹筷木筷铝制筷,哪种适合家用?聪明人选这1种,4个错误别再犯
- 高考志愿怎么挖?永州爱尔眼科带你完美“避坑”!
- 这场交流会,为抗疫一线的人民健康恶魔点赞!
- 6.3万亿的融资租赁业,迈入关键转折点
- 儿童文学家陈纲祖:从小培养孩子的家国伤感
- 收获外援标王+超新星,武汉三镇严肃办大事,目标不止保级,冲前四
- 女子瘦到50斤致多脏器衰竭,减肥可能会都有哪些危害?
- 宝明科技(002992.SZ)拟60亿元在赣州投建锂电池填充铜箔生产基地
- 应届的学校专业毕业生校园招聘会举行 100余所幼儿园进校招聘