zoukankan      html  css  js  c++  java
  • mysql数据索引

      索引是建立在数据库表中的某些列的上面。因此,在创建索引的时候,应该仔细考虑在哪些列上可以创建索引,在哪些列上不能创建索引。一般来说,应该在这些列上创建索引,例如:在经常需要搜索的列上,可以加快搜索的速度;在作为主键的列上,强制该列的唯一性和组织表中数据的排列结构;在经常用在连接的列上,这些列主要是一些外键,可以加快连接的速度;在经常需要根据范围进行搜索的列上创建索引,因为索引已经排序,其指定的范围是连续的;在经常需要排序的列上创建索引,因为索引已经排序,这样查询可以利用索引的排序,加快排序查询时间;在经常使用在WHERE子句中的列上面创建索引,加快条件的判断速度。

      同样,对于有些列不应该创建索引。一般来说,不应该创建索引的的这些列具有下列特点:

    第一,对于那些在查询中很少使用或者参考的列不应该创建索引。这是因为,既然这些列很少使用到,因此有索引或者无索引,并不能提高查询速度。相反,由于增加了索引,反而降低了系统的维护速度和增大了空间需求。

    第二,对于那些只有很少数据值的列也不应该增加索引。这是因为,由于这些列的取值很少,例如人事表的性别列,在查询的结果中,结果集的数据行占了表中数据行的很大比例,即需要在表中搜索的数据行的比例很大。增加索引,并不能明显加快检索速度。

    第三,对于那些定义为text, image和bit数据类型的列不应该增加索引。这是因为,这些列的数据量要么相当大,要么取值很少。

    第四,当修改性能远远大于检索性能时,不应该创建索引。这是因为,修改性能和检索性能是互相矛盾的。当增加索引时,会提高检索性能,但是会降低修改性能。当减少索引时,会提高修改性能,降低检索性能。因此,当修改性能远远大于检索性能时,不应该创建索引。

     例1 ALTER TABLE mytable ADD INDEX name_city_age (name(10),city,age);

      建立这样的组合索引,其实是相当于分别建立了下面三组组合索引:

      usernname,city,age   usernname,city   usernname  为什么没有 city,age这样的组合索引呢?这是因为MySQL组合索引“最左前缀”的结果。简单的理解就是只从最左面的开始组合。并不是只要包含这三列的查询都会用到该组合索引,下面的几个SQL就会用到这个组合索引:

        SELECT * FROM mytable WHREE username="admin" AND city="洛阳"  SELECT * FROM mytable WHREE username="admin"

      而下面几个则不会用到:

      SELECT * FROM mytable WHREE age=20 AND city="洛阳"  SELECT * FROM mytable WHREE city="洛阳"

    这里可以使用日志说明sql语句的优化,针对聚焦索引和非聚焦索引的索引列的优化

    索引失效:

    1,如果条件中有or,即使其中有条件带索引也不会使用(这也是为什么尽量少用or的原因)  ( 注意:要想使用or,又想让索引生效,只能将or条件中的每个列都加上索引 )

    2,如上面例1所示,多个索引时,没有使用第一个索引,则索引失效

    3,like查询中,%放在前面,索引失效,放在后面,索引生效

    4,如果列类型是字符串,那一定要在条件中将数据使用引号引用起来,否则不使用索引

  • 相关阅读:
    [R] read.table的check.names参数防止读入数据时列名前自动加上"X."
    【宏基因组】MEGAN4,MEGAN5和MEGAN6的Linux安装和使用
    洛谷—— P1077 摆花
    洛谷—— P2733 家的范围 Home on the Range
    BZOJ——T 1801: [Ahoi2009]chess 中国象棋
    洛谷—— P1379 八数码难题
    BZOJ——T 1800: [Ahoi2009]fly 飞行棋
    几种outofmemory
    几种常见web攻击手段及其防御方式
    JVM参数
  • 原文地址:https://www.cnblogs.com/ningheshutong/p/8126382.html
Copyright © 2011-2022 走看看