索引与排序

排序可能发生2种情况:

  1: 对于覆盖索引,直接在索引上查询时,就是有顺序的, using index

  2: 先取出数据,形成临时表做filesort(文件排序,但文件可能在磁盘上,也可能在内存中)

  我们的争取目标-----取出来的数据本身就是有序的! 利用索引来排序.

 

比如: goods商品表, (cat_id,shop_price)组成联合索引,

    where cat_id=N order by shop_price ,可以利用索引来排序,

 

select goods_id,cat_id,shop_price from goods order by shop_price;

  // using where,按照shop_price索引取出的结果,本身就是有序的.

 

 

select goods_id,cat_id,shop_price from goods order by click_count;

    // using filesort 用到了文件排序,即取出的结果再次在磁盘排序

 

 

 

重复索引与冗余索引

 

重复索引:(不允许)

重复索引: 是指 在同1个列(如age), 或者 顺序相同的几个列(age,school), 建立了多个索引,称为重复索引, 重复索引没有任何帮助,只会增大索引文件,拖慢更新速度, 去掉.

 

mysql> alter table t7 add index url1(url);
Query OK, 0 rows affected (0.67 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table t7 add index url2(url);
Query OK, 0 rows affected, 1 warning (0.50 sec)
Records: 0  Duplicates: 0  Warnings: 1

  mysql语法上是允许通过的,但是没有实际意义,只会增大索引文件。

 

 

mysql> show create table t7\G
*************************** 1. row ***************************
       Table: t7
Create Table: CREATE TABLE `t7` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `url` varchar(40) DEFAULT NULL,
  `crcurl` int(10) unsigned NOT NULL DEFAULT '0',
  PRIMARY KEY (`id`),
  KEY `url` (`url`(15)),
  KEY `crcurl` (`crcurl`),
  KEY `url1` (`url`),
  KEY `url2` (`url`)
) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8
1 row in set (0.02 sec)

 

 

 

 冗余索引(允许)

 

冗余索引是指2个索引所覆盖的列有重叠, 称为冗余索引

比如 x,m,列 , 加索引 index x(x), index xm(x,m)

  x,xm索引, 两者的x列重叠了, 这种情况,称为冗余索引.

 

甚至可以把 index mx(m,x) 索引也建立, mx, xm 也不是重复的,因为列的顺序不一样.

  mx(m,x)是先排序m,再排序x

  xm(x,m)是先排序x,再排序m

 

 

 

 

【当你用心写完每一篇博客之后,你会发现它比你用代码实现功能更有成就感!】