MySQL-8.索引

本文地址:https://www.jianshu.com/p/a1ea26b9ac3a

一、简介

什么是索引呢?可能初学者常常会听到这个词,但是不明白是什么意思。其实简单来说,索引就是一种优化查询速度的方式。

一般的应用使用数据库时,读写数据的比例大概在10:1之间,也就是说,执行查询语句的比例远远大于写入。所以,查询语句的运行效率常常决定着一个应用的性能瓶颈,而索引就是一个牺牲写入效率,提升查询效率的工具。

在没有建立索引的表中,如果要去查询一条数据,那么就必须全盘扫描整张表,知道找到目标数据为止。而建立了索引的表中,索引就好像是字典中的目录,通过特定算法记录着我们存储数据的指针,可以让我们搜索数据的速度大大缩短。目前MySQL数据库主要支持的索引类型有B-treeHASH


二、索引的优劣

优点

  1. 能大大的加快数据库中查询的速度。

缺点

  1. 索引会占用额外的存储空间,如果创建索引过多,占用空间会很大。
  2. 在对建立了索引的表中写入数据时,索引需要动态的维护。也就是说,会影响写入数据的效率。

注意事项

  1. 避免给经常更新的表建立太多索引,以免影响太多写入效率。
  2. 建立索引的字段,越短越好,数值类型越简单越好。
  3. 尽量避免字段中出现NULL,因为NULL值的查询是不走索引的,含空值的列是很难做查询优化的。所以要在建立字段时加上NOT NULL的约束条件,空值用0或者空字符代替。
  4. 索引不要盲目建立,一般只需要给在WHEREJOIN字句中需要出现的字段建立索引即可。
  5. 建立索引后,查询的时候不要进行运算,因为运算的话会变成全表查询。只有这些运算符:<<==>>=BETWEENIN,以及某些时候的LIKE会被索引支持。

三、索引的分类

由于MySQL支持的引擎类型较多,而索引是在存储引擎中实现的,所以不同的存储引擎有不同的索引方式。常用的InnoDBMyISAM引擎都只能使用B-tree索引。

根据索引的使用方式,也分为单列索引组合索引全文索引空间索引,这其中单例索引又分为普通索引唯一索引主键索引


四、单列索引

单列索引指的是这个索引只对单个列起作用。

4.1. 普通索引

以下是创建普通索引三种的方式:

CREATE INDEX indexName ON tbname(colname(length));
ALTER table tableName ADD INDEX indexName(colname);
CREATE TABLE tbname(
ID INT NOT NULL,
username VARCHAR(16) NOT NULL,
INDEX [indexName] (colname(length))
);  

创建索引时,如果字段是CHARVARCHAR类型,length可以小于字段实际长度。如果是BLOBTEXT类型,必须指定length

同时,索引的名字也是可选的,如果没有指定名字的话,那么MySQL会默认用字段名作为索引的名字。

索引建好之后,可以使用以下命令查看:

SHOW INDEX FROM table_name;

同样也可以使用以下命令删除普通索引:

DROP INDEX [indexName] ON table_name; 

4.2. 唯一索引

MySQL之中,有一个比较特殊的地方就是,KEYINDEX常常被混淆在一起,虽然说本质上KEYINDEX不是同一个东西,但是究其原因,MySQL中的约束效果是通过索引来实现的,MySQL数据库判断是否当前列是否unique就是通过unique索引判断的。

因为这个原因,所以其实我们的UNIQUE KEY约束条件其实也就建立了索引,两者被完全绑定到了一起。

以下是建立唯一索引的方式:

CREATE UNIQUE INDEX indexName ON tablename(colname(length));
ALTER TABLE table_name ADD UNIQUE indexName ON (colname(length));
CREATE TABLE table (
id int NOT NULL AUTO_INCREMENT,
name varchar(20) NOT NULL,
UNIQUE [indexName] (colname(length))
);

唯一索引的删除方式与普通索引是一致的。

4.3. 主键索引

主键索引也是类似,与主键这个约束条件基本是相同的,创建的方式与主键通用,就不一一赘述了。

这里主要讲一讲InnoDB引擎上主键的选择。在没有特殊需求的情况下,主键都应该使用无关业务逻辑的自增字段。

有人会觉得,使用身份证之类的数据来作为主键也是可以的,但是在算法层面上,如果表使用自增主键,那么每次插入新的记录,记录就会顺序添加到当前索引节点的后续位置,当一页写满,就会自动开辟一个新的页。这样会形成一个紧凑的索引结构,提高效率。

而如果使用的是身份证号这种非自增数据的话,那么数据的值就是类似随机的数据,就达不到这个效果了。


五、组合索引

组合索引其实就是用多个字段做一个索引,在查询时如果有多个字段做为索引条件的话,那么组合索引的效率会大大高于每个字段做一个单列索引。因为MySQL的查询每次只能使用一个索引,所以多个单列索引只会用到一个索引,其他字段的查询就会变成全文搜索。

建立组合索引的方式:

CREATE INDEX indexname On tbName(colname(length),colname(length),...);
ALTER TABLE tbname ADD INDEX indexname (colname(length),colname(length),...);

最左前缀原则

举例来说,如果使用a, b ,c三个字段建立组合索引之后,其实等价于建立了a b c, a b, a三个索引,这主要由建立组合索引时的字段顺序决定。

也就是说,如果使用b c两个字段查询的话,那么组合索引是无效的,所以建立组合索引的时候,一定要详细考虑字段的顺序。


六、全文索引和空间索引

前面有提到,在建立索引的时候,字段的值越短越好。但全文索引则不然,全文索引可以对字段全文搜索,也就是使用文本的一部分,可以搜索出这一整条记录,但只有MyISAM引擎支持全文索引。

空间索引则是对空间数据类型的字段建立的索引。

由于这两种索引使用的比较少,所以就不多赘述了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,968评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,601评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,220评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,416评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,425评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,144评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,432评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,088评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,586评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,028评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,137评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,783评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,343评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,333评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,559评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,595评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,901评论 2 345