数据库进阶(文件的组织方式和索引)

本文详细介绍了数据库中文件的四种组织方式:无序堆文件、有序文件、散列文件和聚簇文件,以及不同组织方式的优缺点。此外,还探讨了索引的概念,包括稠密索引、稀疏索引、主索引和辅助索引,以及B+树和B树索引的工作原理。这些知识对于优化数据库性能至关重要。
摘要由CSDN通过智能技术生成

数据库中文件的组织方式

数据库的组织要考率更新和检索的需求,更新涉及到数据的存储空间的扩展和回收的问题,检索涉及到扫描整个数据库,和大批量处理数据的问题,不同的需求要求不同的数据组织方式和存取方式。

数据的组织方法是指数据组成记录,块,和访问结构的方式,包括把记录和块存储在磁盘上的方式,以及块和记录之间的相互联系。
存取方法是指对文件所采取的存取操作方法。
一种文件组织可以采取多种存取方法进行访问

无序的文件组织方法(堆文件heap 或pile file)

特点:记录可以存储在任意的空间位置,磁盘上的存
储记录是无序的,更新效率高,但是检索效率低。
这里写图片描述
方法一:每一次插入数据都插入到数据的尾部,删除数据的时候我们将被删除的记录做一个标记,不做标记的话会涉及到大规模的数据移动,是不安全的。
方法2:在被标记的基础上,如果插入数据所占用的空间小于被标记的空间将新的记录插入到被标记的记录处。
但是频繁的更新数据会造成空间的浪费,导致数据库性能下降,所以需要周期性重新组织数据库。即数据库重组。

有序的文件组织(Sequential file)

特点:记录按照某个属性或者属性组值得顺序插入,磁盘上的存储记录是有序的,检索的效率可能高。
用于存储排序的字段通常称为排序字段,排序字段一般使用关系之中的主键,又称为排序码当按排序字段检索的时候检索的速度会得到提高,但是当按照非排序字段检索的时候检索的速度不会提高很多。但是有序的文件组织的更新效率比较低,因为在插入数据的时候要大规模的移动数据为插入数据留出空间而且是不安全的。
改进:使用一个临时无序文件(溢出文件)保留新增记录。当采取溢出文件的时候检索既要操作主文件又要操作溢出文件,所以需要周期性的重组数据库。

散列文件组织(hash file)

特点:将记录某个属性或者属性组值,依据散列函数计算出其应该存放的位置:

  • 6
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值