谈谈索引文件

本来是去查B-Tree的,翻到了索引文件,看了两眼,备忘一下吧。

什么是索引文件?
除了文件本身(即数据区)之外,另建立一张表只是逻辑记录和物理记录之间的意义对应关系的表---索引表,这类包括文件数据区和索引表两大部分的文件叫做索引文件。

索引表示由系统自动生成的,在记录输入建立数据区的同时建立一个索引表,按输入次序排列,输入完毕之后再对索引表进行排序。

索引为什么快?
首选,索引是有序的,所以就可以按照折半查找法。
其次,索引项的长度通常远远小于记录的长度,可以直接放进内存,读取速度也快。这样子就只有读索引,读文件两次读取外村,速度快。
当然未必所有的情况都可以全放进内存,如果一个物理块放不下,可以对索引表再建索引,称之为查找表,第二查找表,第三查找表。

多级索引又分为静态索引和动态索引。
静态索引的各级索引均为顺序结构,但是修改时就需要重组索引,所以变动多时不适合用静态而应该用动态。
如果文件记录数不多,索引表也不大,内存可一次容纳的话,可以选用二叉排序树或平衡树做索引;
如果记录数很多,索引表也在外存,此时需要用B-Tree做索引;
还有一种是键树,适合特殊类型的关键字的索引表。

总之,对外存中的索引表的查找速度取决于访问外存的速度,即索引表的深度。

关于ISAM,VSAM和hash文件。。。待续。。。原来MYISAM不是mysql专享的啊,哈哈。。。发现,这部分通篇都是文件二字。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值