关于索引(1)

  • 什么是索引?

索引是存储引擎用于快速找到记录的一种数据结构,也就是说索引是种数据结构。
在MySQL中,索引是在存储引擎层而不是在服务器层实现的,所以不同的存储引擎的索引的工作方式也是不一样的。

  • 建立索引的目的? 提高查找效率,索引就是类比字典的作用!
  • 为什么可以提高查询效率 ?

    可以简单理解为排好序且快速查找的数据结构,也就是说会影响where后面的查找,以及order by后面的排序;
    我们知道,在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这种数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构的基础上实现高级查找算法;其实简单理解起来也就类似于编程语言中的new对象,=右边才是实体,而=号左边只是指针引用。
    索引的数据结构是基于B-Tree的,意味着所有的值都是按顺序存储的,并且每一个叶子页到根的距离相同;而且B-Tree索引能够加快访问数据的速度,因为存储引擎不再需要进行全表扫描来获取需要的数据,取而代之的是从索引的根节点进行搜索。根节点的槽中存放了指向子节点的指针,存储引擎根据这些指针向下层查找。通过比较节点页的值和要查找的值可以找到合适的指针进入下层子节点,这些指针实际上定义了子节点页中值的上限和下限,最终存储引擎要么是找到对应的值,要么该记录不存在。叶子节点比较特别,他们的指针指向的是被索引的数据,而不是其他的节点页。

  • 建立索引的优势和劣势
    1.优势:提高数据检索的效率,降低数据库的IO,至于原因我们会在后面展开,通过索引列对数据进行排序,降低数据排序的成本,降低了CPU的消耗;索引还大大减少了服务器需要扫描的数据量,索引可以帮助服务器减少服务器避免排序和临时表,而且索引可以将随机I/O变为顺序I/O。
    2.劣势:虽然索引大大提高了查询速度,同时却会降低更新表的速度,比如对表进行insert,update和delete操作,因为更新表时,mysql不仅保存数据,还要保存一下索引文件,每次添加了索引列的字段,都会调整更新所带来的键值变化后的索引信息;索引只是提高效率的一个因素,如果你的Mysql有大数据量的表,就需要花时间建立最优秀的索引,或者优化查询,或者分表,分库等等操作。
  • 索引的分类(建议:一个表最多建的索引不超过5个)
    1.单值索引:即一个索引只包含一个列,一个表可以有多个单列索引
    2.唯一索引:索引列的值必须唯一,但允许有空值;
    3.复合索引:即一个索引包含多个列;
  • 相关的命令
    1.创建索引
     create  [unique] index idxName on tableName (columnName(length));
     alter tableName add [unique] index  idxName on (columnName(length));
    
    2.删除索引
     drop index idxName on tableName;
    
    3.查看索引
     show index from tableName\G;
    
  • 何种情况下适合创建索引?
    1.主键自动建立唯一索引;
    2.频繁作为查询条件的字段应该建立索引;
    3.查询中与其他表关联的字段,外键关系建立索引;
    4.频繁更新的字段不适合建立索引,因为每次更新不单单是更新了记录还会更新索引文件数据记录,也就是二叉树的节点数据。
    5.where条件里用不到的字段不适合创建索引;
    6.单值/复合索引的选择问题?在高并发下倾向于创建组合索引;
    7.查询中排序的字段,排序字段若通过索引去访问将大大提高排序速度;
    8.查询中统计或者分组的字段;
  • 何种情况下不适合创建索引?
    1.表记录太少(mysql起码300w的数据吧);
    2.经常增删改的表;
    3.数据重复且分布平均的表字段,因此应该只为经常查询和最经常排序的数据建立索引。注意:如果某个数据列包含许多重复的内容,为它建立索引就没有太大的实际效果。比如: 假如一个表有10w行记录,有一个字段A只有true和false两种值,且每个值得分布概率大约为50%,那么对这种字段建索引一般不会提高查询效率的。
    索引的选择性是指索引列中不同值的数目与表中记录数的比,如果一个表中有2000条记录,表索引列有1980个不同的值,那么这个索引的选择性就是1980/2000=0.99。一个索引的选择性越接近于1,这个索引的效率越高。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容