zoukankan      html  css  js  c++  java
  • 索引的优点

      索引可以让服务器跨苏的定位到指定的位置。但是这病不是索引的唯一作用,到目前位置都可以看到,根据创建索引的数据结构不同,索引也有一些其他的附加作用。

      最常见的是B-Tree索引,按照属性存储的数据,所以MySQL 可以用来做ORDER BY 和GROUP BY 操作。因为数据是有序的,所以B-Tree也就会将相关的列值存储在一起。最后,因为索引中存储了实际的列值,所以某些查询值使用索引就能够完成全部查询。据此特性,总结下来索引有如下三个优点:

      1 索引大大减少了服务器要扫描的数据量。

      2 索引可以帮助服务器避免排序和临时表。

      3 索引可以将随机的IO变为顺序IO.

    TIPS :索引是最好的解决方案吗:

      索引并不总是最好的工具。总的来说,只有当索引帮助存储引擎开始查找到记录带来的好处大于其带来的额外工作时,索引才是有效的。对于非常小的表,大部分情况下全表扫描的更高效。对于中到大型的表,索引就非常有效。但是对于特大型的表,简历和使用所用的代价将会随之增长。这种情况下,则需要一种技术可以直接区分查询需要的一组数据,而不是一条一条记录的匹配。例如可以使用分区技术(以后会讲)。

      如果表的数量特别多,可以建立一个元数据信息表,用来查询需要用到的某些特性。例如执行那些需要聚合多个应用分布在多个表的数据的查询,则需要记录’‘那个用户信息存储在那个表中’的元数据,这样在查询时就可以直接忽略那些不包含指定用户信息的表。对于大型系统,这是一个常用的技巧。事实上,infobright 就是使用类似的实现。对于TB级别的数据,定位单条记录的一一不大,所以经常会使用块级别元数据替代索引。

  • 相关阅读:
    codevs 1115 开心的金明
    POJ 1125 Stockbroker Grapevine
    POJ 2421 constructing roads
    codevs 1390 回文平方数 USACO
    codevs 1131 统计单词数 2011年NOIP全国联赛普及组
    codevs 1313 质因数分解
    洛谷 绕钉子的长绳子
    洛谷 P1276 校门外的树(增强版)
    codevs 2627 村村通
    codevs 1191 数轴染色
  • 原文地址:https://www.cnblogs.com/zhengyanqiu/p/4979248.html
Copyright © 2011-2022 走看看