什么是索引?为什么要建立索引

索引用于快速找出在某个列中有一特定值的行,不使用索引MySQL必须从第一条记录开始读完整个表,直到找出相关的行,表越大查询数据所花费的时间就越多,如果表中查询的列有一个索引,MySQL能够快速到达一个位置去搜索数据文件,而不必查看所有数据,那么将会节省很大一部分时间。

例如:有一张person表,其中有2W条记录,记录着2W个人的信息。有一个Phone的字段记录每个人的电话号码,现在想要查询出电话号码为xxxx的人的信息。

如果没有索引,那么将从表中第一条记录一条条往下遍历,直到找到该条信息为止。

如果有了索引,那么会将该Phone字段,通过一定的方法进行存储,好让查询该字段上的信息时,能够快速找到对应的数据,而不必在遍历2W条数据了。其中MySQL中的索引的存储类型有两种:BTREE、HASH。 也就是用树或者Hash值来存储该字段,要知道其中详细是如何查找的,需要一定的算法知识了。

B-Tree

B-Tree索引,它是目前关系型数据库中查找数据最为常用和有效的索引,大多数存储引擎都支持这种索引。使用B-Tree这个术语,是因为MySQL在CREATE TABLE或其它语句中使用了这个关键字,但实际上不同的存储引擎可能使用不同的数据结构,比如InnoDB就是使用的B+Tree。

B+Tree中的B是指balance,意为平衡。需要注意的是,B+树索引并不能找到一个给定键值的具体行,它找到的只是被查找数据行所在的页,接着数据库会把页读入到内存,再在内存中进行查找,最后得到要查找的数据。

image.png

InnoDB聚簇索引(clustered index)

聚簇索引保证关键字的值相近的元组存储的物理位置也相同(所以字符串类型不宜建立聚簇索引,特别是随机字符串,会使得系统进行大量的移动操作),且一个表只能有一个聚簇索引。因为由存储引擎实现索引,所以,并不是所有的引擎都支持聚簇索引。

聚簇索引:

image.png

二级索引:

image.png

索引的优点和缺点

优点

1、所有的MySql列类型(字段类型)都可以被索引,也就是可以给任意字段设置索引

2、大大加快数据的查询速度

缺点

1、创建索引和维护索引要耗费时间,并且随着数据量的增加所耗费的时间也会增加

2、索引也需要占空间,我们知道数据表中的数据也会有最大上线设置的,如果我们有大量的索引,索引文件可能会比数据文件更快达到上线值

3、当对表中的数据进行增加、删除、修改时,索引也需要动态的维护,降低了数据的维护速度。

使用原则

通过上面说的优点和缺点,我们应该可以知道,并不是每个字段度设置索引就好,也不是索引越多越好,而是需要自己合理的使用。

并不是所有索引对查询都有效

并不是所有索引对查询都有效,SQL是根据表中数据来进行查询优化的,当索引列有大量数据重复时,SQL查询可能不会去利用索引,如一表中有字段 sex,male、female几乎各一半,那么即使在sex上建了索引也对查询效率起不了作用。

索引并不是越多越好

索引固然可以提高相应的 select 的效率,但同时也降低了 insert 及 update 的效率,因为 insert 或 update 时有可能会重建索引,所以怎样建索引需要慎重考虑,视具体情况而定。一个表的索引数较好不要超过6个,若太多则应考虑一些不常使用到的列上建的索引是否有必要。

避免更新聚簇索引数据列

应尽可能的避免更新 clustered 索引数据列,mysql默认的clustered索引为主键,因为 clustered 索引数据列的顺序就是表记录的物理存储顺序,一旦该列值改变将导致整个表记录的顺序的调整,会耗费相当大的资源。若应用系统需要频繁更新 clustered 索引数据列,那么需要考虑是否应将该索引建为 clustered 索引。

经常更新的表就避免对其进行过多的索引

对经常更新的表就避免对其进行过多的索引,对经常用于查询的字段应该创建索引。

数据量小的表最好不要使用索引

数据量小的表最好不要使用索引,因为由于数据较少,可能查询全部数据花费的时间比遍历索引的时间还要短,索引就可能不会产生优化效果。

避免在不同值少的列上加索引

在一不同值少的列上(字段上)不要建立索引,比如在学生表的"性别"字段上只有男,女两个不同值。相反的,在一个字段上不同值较多可以根据需要建立索引。

根据业务需求建立索引

索引的建立要根据业务特点进行,不能凭空想象的设置索引。经常作为查询条件的列才有建立索引的必要性。

mysql 字符串 索引优化_轻松优化MySQL-之索引优化1相关推荐

  1. mysql mvcc实例讲解_轻松理解MYSQL MVCC 实现机制

    1. MVCC简介 1.1 什么是MVCC MVCC是一种多版本并发控制机制. 1.2 MVCC是为了解决什么问题? 大多数的MYSQL事务型存储引擎,如,InnoDB,Falcon以及PBXT都不使 ...

  2. 大于小于优化_架构 - 以MySQL为例,详解数据库索引原理及深度优化

    一.摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持也各不相同,因此MySQL数据库支持多种索引类型,如 ...

  3. 由浅入深探究mysql索引结构原理_性能分析与优化_由浅入深探究mysql索引结构原理、性能分析与优化...

    由浅入深探究mysql索引结构原理.性能分析与优化 第一部分:基础知识第二部分:MYISAM和INNODB索引结构1, 简单介绍B-tree B+ tree树 2, MyisAM索引结构 3, Ann ...

  4. mysql sql优化_浅谈mysql中sql优化

    说到sql优化,一般有几个步骤呢,在网上看到了一篇很不错的帖子.在这分享一下吧,也是自己学习的一个过程. 一.查找慢查询 1.1.查看SQL执行频率 SHOW STATUS LIKE 'Com_%'; ...

  5. mysql 表结构监控_性能测试之mysql监控、优化

    共享表空间还有一个缺点就是不能自动收缩,自动收缩是什么意思呢,刚建表的时候,表里面数据很少,就1条数据,可能占用空间就几kb,到后来数据多了,占用了10个G的空间,然后发现有一些数据都是垃圾数据,删了 ...

  6. 谈谈mysql优化_浅谈MySQL SQL优化

    本文首发于个人微信公众号<andyqian>,期待你的关注 前言 有好几天没有写文章了,实在不好意思.之前就有朋友希望我写写MySQL优化的文章.我迟迟没有动笔,主要是因为,SQL优化这个 ...

  7. 高性能mysql 第六章_第六章 查询性能优化

    1. 为什么查询速度会慢 如果把查询看作是一个任务,那么它由一系列子任务组成,每个子任务都会消耗一定的时间.如果要优化,无非是减少子任务数量,或者减少子任务的执行次数. 查询声明周期:生成计划,执行, ...

  8. mysql 行锁 超时_技术分享 | MySQL 行锁超时排查方法优化

    作者:xuty 本文来源:原创投稿 * 爱可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源. 一.大纲 #### 20191219 10:10:10,234 | com.ali ...

  9. MySQL线上优化_线上MySQL千万级大表,如何优化?

    前段时间应急群有客服反馈,会员管理功能无法按到店时间.到店次数.消费金额进行排序.经过排查发现是 SQL 执行效率低,并且索引效率低下. 图片来自 Pexels 应急问题 商户反馈会员管理功能无法按到 ...

最新文章

  1. mysql聚集索引可以多列吗_MySQL使用单列索引和多列索引
  2. 钉钉总裁不穷首谈产品观:To B产品用户不只是CEO
  3. 我的世界java版如何装mod_Minecraft如何安装Mod?Minecraft添加Mod的方法
  4. 快速排序算法_经常用到的的排序(快速排序和归并排序)简单的计算机算法学习...
  5. 牛客网暑期ACM多校训练营(第五场): A. gpa(01分数规划)
  6. 如何隐藏地址栏中的真实地址_代理IP如何隐藏真实IP
  7. mysql generator 命令_Mybatis使用命令生成逆向工程的方法
  8. Lvgl7 基础对象(lv_obj)
  9. 中科院华为诺亚提出ViG:一种全新的骨干网络,性能不输CNN、ViT!
  10. 将checkbox选中样式用图片替换
  11. gif透明背景动画_BMP、GIF、TIFF、PNG、JPG和SVG格式图像的特点
  12. 锐界机器人_钱江机器人/海峰机器人/锐界科技彰显“装配”技术实力
  13. 九年级计算机课教学计划,九年级下学期计算机学科教学计划.doc
  14. 基于Android实现的小型在线订餐APP饿了么
  15. 关于javax.validation.Validator校验的使用
  16. Android白眉鹰王之BroadcastReceiver
  17. 将图片转换为Icon
  18. 界面开发Ribbon元素该被淘汰了吗
  19. Web-Design 如何选择虚拟主机?
  20. 电子技术——共模抑制

热门文章

  1. apache+mysql+php的环境配置
  2. TCP、UDP及IP协议总结
  3. Linux下使用ps命令来查看Oracle相关的进程
  4. 【转载】linux进程控制-exec系列 exec系统调用
  5. redis 配置文件参数详解
  6. Intel HEX文件解析
  7. 【项目实施随笔】销售和采购信息的打印
  8. 为什么使用JDBC数据库编程
  9. 小爬爬1:jupyter简单使用爬虫相关概念
  10. Beta冲刺 第一天