所有MySQL列类型都可以被索引,对相关列使用索引是提高SELECT操作性能的最佳途径。根据存储引擎可以定义每个表的最大索引数和最大索引长度,每种存储引擎(如MyISAM、InnoDB、BDB、MEMORY 等)对每个表至少支持16个索引,总索引长度至少为256 字节。

一、索引创建、查询与删除

1. 索引创建

  索引可以在创建表的时候同时创建,也可以使用alter table命令或create index命令随时增加新的索引。

create index命令语法:

CREATE [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name

[USING index_type]

ON tbl_name (index_col_name,...)

参数解析:

index_type:btree、hash...

index_col_name:col_name [(length)] [ASC | DESC]

前缀索引创建实例:

create index ind_company2_name on company2(name(4));

复合索引创建实例:

create index ind_sales2_companyid_moneys on sales2(company_id,moneys);

2. 索引查询:

show index from tbl_name;

show keys from tbl_name;

3. 索引删除:

drop index index_name on tbl_name;

二、索引存储分类

  MySQL 中索引的存储类型目前只有两种(BTREE 和HASH),具体和表的存储引擎相关:MyISAM 和InnoDB 存储引擎都只支持BTREE索引;MEMORY/HEAP存储引擎可以支持HASH和BTREE索引(Memory存储引擎默认使用HASH索引)。Mysql目前还不支持函数索引,但是支持前缀索引,即对索引字段的前N个字符创建索引。

  MyISAM 存储引擎的表的数据和索引是自动分开存储的,各自是独立的一个文件;InnoDB存储引擎的表的数据和索引是存储在同一个表空间里面,但可以有多个文件组成。

BTREE索引和HASH索引的差异:

(1)HASH索引只用于使用=或<>操作符的等式比较。如果一定要使用范围查询的话,只能使用BTREE索引。

(2)优化器不能使用Hash索引来加速order by操作。

(3)使用Hash索引时MySQL不能确定在两个值之间大约有多少行。如果将一个MyISAM表改为的Hash索引memory表,会影响一些查询的执行效率。

(4)Hash索引只能使用整个关键字来搜索一行。

 三、索引设计的原则

1. 最适合索引的列是出现在where子句中的列,或连接子句中指定的列。

2. 使用唯一索引。索引的列的基数越大,索引的效果越好。

3. 使用短索引。如果对字符串列进行索引,应该指定一个前缀长度,这样可以节省大量索引空间,也可能会使查询更快。

4. 利用最左前缀。在创建一个n列的索引时,实际上是创建了MySQL可利用的n个索引。多列索引可起几个索引的作用,因为可利用索引中最左边的列集来匹配行,这样的列集称为最左前缀。

5. 不要过度索引。每个额外的索引都要占用额外的磁盘空间,并降低写操作的性能。

6. 对于InnoDB存储引擎的表,记录默认会按照主键或唯一索引或内部列的顺序保存。按照主键或者内部列进行的访问是最快的,所以要选择最常作为访问条件的列作为主键,提高查询的效率。InnoDB表的普通索引都会保存主键的键值,所以主键要尽可能选择短的数据类型,可以有效地减少索引的磁盘占用,提高索引的缓存效果。

四、索引使用

1. 使用索引

(1)对于多列索引,只要查询的条件中用到了最左边的前缀,索引一般就会被使用。

(2)对于使用like 的查询,后面如果是常量并且只有%号不在第一个字符,索引才可能会被使用,如果如果like后面跟的是一个列的名字,那么索引也不会被使用。

(3)如果对大的文本进行搜索,使用全文索引而不用使用like ‘%…%’。

(4)如果列名是索引,使用column_name is null 将使用索引。

2. 存在索引但不使用索引

(1)如果MySQL估计使用索引比全表扫描更慢,则不使用索引。

(2)如果使用MEMORY/HEAP 表并且where 条件中不使用“=”进行索引列,那么不会用到索引。heap 表只有在“=”的条件下才会使用索引。

(3)用or分割开的条件,如果出现一个条件的列没有索引的话,那么涉及到的索引都不会被用到。

(4)对于复合索引,如果条件中不是索引列的前缀,索引也不会被用到。

(5)使用like的查询如果后面的常量是以%开头,不会使用索引。

(6)如果列类型是字符串,那么一定记得在where条件中把字符常量值用引号引起来,否则的话即便这个列上有索引,MySQL也不会用到的,因为,MySQL默认把输入的常量值进行转换以后才进行检索。

3. 查看索引的使用情况

show status like 'Handler_read%';

  如果索引正在工作,Handler_read_key 的值将很高,这个值代表了一个行被索引值读的次数,很低的值表明增加索引得到的性能改善不高,因为索引并不经常使用。Handler_read_rnd_next 的值高则意味着查询运行低效,并且应该建立索引补救。这个值的含义是在数据文件中读下一行的请求数。如果正进行大量的表扫描,Handler_read_rnd_next的值较高,则通常说明表索引不正确或写入的查询没有利用索引。

4. 使用SQL提示

(1)use index

  在查询语句中表名的后面,添加use index来可以提供希望MySQL 去参考的索引列表,就可以让MySQL不再考虑其他可用的索引。

使用示例:

select * from sales2 use index (ind_sales2_id) where id = 3;

(2)ignore index

  让MySQL忽略一个或多个索引。

(3)force index

  强制Mysql使用一个特定的索引。

转载于:https://www.cnblogs.com/wujuntian/p/5935971.html

MySQL索引(1)相关推荐

  1. mysql索引空间太大_MySQL优化索引

    1.  MySQL如何使用索引 索引用于快速查找具有特定列值的行.如果没有索引,MySQL必须从第一行开始,然后遍历整个表以找到相关的行.表越大,花费越多.如果表中有相关列的索引,MySQL可以快速确 ...

  2. mysql索引教程_MySQL教程96-MySQL索引类型

    索引的类型和存储引擎有关,每种存储引擎所支持的索引类型不一定完全相同.MySQL 索引可以从存储方式.逻辑角度和实际使用的角度来进行分类. 存储方式区分 根据存储方式的不同,MySQL 中常用的索引在 ...

  3. mysql 树形结构_再读MySQL索引-《高性能MySQL》索引手记

    最近工作中经常和MySQL打交道,当数据量小的时候,不同查询方式以及是否使用索引并无大碍,当数据量随着业务的成长急剧加速时,索引的重要性不言而喻. 本篇文章以<高性能MySQL>中的索引章 ...

  4. MySQL索引背后的数据结构及算法原理【转】

    http://blog.codinglabs.org/articles/theory-of-mysql-index.html MySQL索引背后的数据结构及算法原理[转] 摘要 本文以MySQL数据库 ...

  5. mysql 索引合并

    索引合并是mysql底层为我们提供的智能算法.本文就介绍了mysql 索引合并的使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 索引合并是mysql底层为我们提 ...

  6. mysql中groupby会用到索引吗_开发人员不得不知的MySQL索引和查询优化

    本文主要总结了工作中一些常用的操作及不合理的操作,在对慢查询进行优化时收集的一些有用的资料和信息,本文适合有 MySQL 基础的开发人员. 索引相关 索引基数 基数是数据列所包含的不同值的数量,例如, ...

  7. mysql索引底层实现原理_mysql的索引底层之实现原理

    MySQL索引背后的数据结构及算法原理 一.定义 索引定义:索引(Index)是帮助MySQL高效获取数据的数据结构. 本质:索引是数据结构. 二.B-Tree m阶B-Tree满足以下条件: 1.每 ...

  8. 不会MySQL索引,面试官让回家等通知!

    " 你是不是对于 MySQL 索引的知识点一直都像大杂烩,好像什么都知道,如果进行深究的话可能一个也答不上来. 假如你去面试,面试官让你聊一下对索引的理解,然而你对索引的理解仅限于,检索数据 ...

  9. ElasticSearch 索引 VS MySQL 索引

    前言 这段时间在维护产品的搜索功能,每次在管理台看到 elasticsearch 这么高效的查询效率我都很好奇他是如何做到的. 这甚至比在我本地使用 MySQL 通过主键的查询速度还快. 为此我搜索了 ...

  10. mysql索引排序算法_MySQL中利用索引对数据进行排序的基础教程

    MySQL中,有两种方式生成有序结果集:一是使用filesort,二是按索引顺序扫描.利用索引进行排序操作是非常快的,而且可以利用同一索引同时进行查找和排序操作.当索引的顺序与ORDER BY中的列顺 ...

最新文章

  1. torchtext语料库 词与 下标互转使用教程
  2. 应用中有使用到集群么?多大规模?
  3. python爬取动态网站
  4. oracle查看执行最慢与查询次数最多的sql语句
  5. 【SSH进阶】No result defined for action **的解决方案
  6. vue3中这几个变化你要注意了
  7. py2exe打包python_Python打包-py2exe使用
  8. Spring-02-AOP切面编程
  9. Visual Studio使用ILDasm反汇编工具查看托管模块
  10. 带农历万年历C语言程序,c语言万年历程序代码
  11. 清理系统垃圾 bat
  12. Java实现经纬度格式转化
  13. AI大军已经兵临城下,我们离失业还有多远?
  14. “硬解码”与“软解码”的区别
  15. Polar SC的C++实现
  16. Stacked Attention Networks for Image Question Answering(用于图像问答的堆叠注意力网络)
  17. .net 本地文件管理 代码_如何在百万行代码中发现隐藏的后门
  18. 【JavaScript】this指向经典面试题(超详细)
  19. Android保存图片和视频到本地并更新相册
  20. 用计算机做出牙膏盒立体效果制作,使用Nuke进行2D转3D立体世界详解案例教程(二):制作3D立体效果...

热门文章

  1. 2020年面向前端开发人员的10个最佳CSS框架
  2. 【数据库】MySQL表的增删改查
  3. mysql文件_mysql 的各种文件详细说明
  4. 无法获取计算机名,Spring Cloud常见问题之:无法注册主机名
  5. 修改 decimal 默认值为0.00 sql_书写高性能SQL语句技巧,网友都说好
  6. python中的条件判断稀硫酸_大学mooc2020用Python玩转数据期末考试查题公众号答案...
  7. btoa java_javascript atob()函数和 btoa()函数-Base64的编码与解码-Go语言中文社区
  8. vfp 界面_VFP之老树新花
  9. 背包问题(nyoj106)
  10. Tomcat执行start文件后有乱码