所有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使用一个特定的索引。

MySQL索引(1)的更多相关文章

  1. 深入MySQL索引

    MySQL索引作为数据库优化的常用手段之一在项目优化中经常会被用到, 但是如何建立高效索引,有效的使用索引以及索引优化的背后到底是什么原理?这次我们深入数据库索引,从索引的数据结构开始说起. 索引原理 ...

  2. MySQL 索引

    MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度. 打个比方,如果合理的设计且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是 ...

  3. MYSQL索引结构原理、性能分析与优化

    [转]MYSQL索引结构原理.性能分析与优化 第一部分:基础知识 索引 官方介绍索引是帮助MySQL高效获取数据的数据结构.笔者理解索引相当于一本书的目录,通过目录就知道要的资料在哪里, 不用一页一页 ...

  4. MySQL索引原理及慢查询优化

    原文:http://tech.meituan.com/mysql-index.html 一个慢查询引发的思考 select count(*) from task where status=2 and ...

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

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

  6. [转]MySQL索引背后的数据结构及算法原理

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

  7. MySQL索引类型总结和使用技巧以及注意事项

    索引是快速搜索的关键.MySQL索引的建立对于MySQL的高效运行是很重要的.下面介绍几种常见的MySQL索引类型 在数据库表中,对字段建立索引可以大大提高查询速度.假如我们创建了一个 mytable ...

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

    本文来自:张洋的MySQL索引背后的数据结构及算法原理 摘要 本文以MySQL数据库为研究对象,讨论与数据库索引相关的一些话题.特别需要说明的是,MySQL支持诸多存储引擎,而各种存储引擎对索引的支持 ...

  9. mysql索引总结----mysql 索引类型以及创建

    文章归属:http://feiyan.info/16.html,我想自己去写了,但是发现此君总结的非常详细.直接搬过来了 关于MySQL索引的好处,如果正确合理设计并且使用索引的MySQL是一辆兰博基 ...

  10. Mysql 索引实现原理. 聚集索引, 非聚集索引

    Mysql索引实现: B-tree,B是balance,一般用于数据库的索引.使用B-tree结构可以显著减少定位记录时所经历的中间过程,从而加快存取速度.而B+tree是B-tree的一个变种,My ...

随机推荐

  1. Struts访问的时候出现request=null的情况

    今天用Struts框架写个小应用的时候,出现了如下问题 private File upload;    private String uploadContentType;    private Str ...

  2. java如何将html过滤为纯文本

    java开发中jsp页面可以嵌套很多插件就可以将html形式的文本直接转化为纯文本,但是如果你已经保存下来或者没有运用插件,这个额html形式的文本你该怎么转化为纯文本呢?有次我将公告保存了html形 ...

  3. Python循环列表删除元素问题

    有人会遇到这种问题,遍历列表,想删除列表中的某几个元素,执行后发现有些并没有删除到, 比如以下代码 a=[1,2,3,4,5,6]print(a) for i in a: if i==3 or i== ...

  4. 基于FPGA的腐蚀膨胀算法实现

    本篇文章我要写的是基于的腐蚀膨胀算法实现,腐蚀膨胀是形态学图像处理的基础,,腐蚀在二值图像的基础上做"收缩"或"细化"操作,膨胀在二值图像的基础上做" ...

  5. mybatis枚举映射成tinyint

    第一步:定义顶级枚举接口 public interface BaseEnum<E extends Enum<?>, T> { public T getCode(); publi ...

  6. Kafka快速上手(2017.9官方翻译)

    为了帮助国人更好了解.上手kafka,特意翻译.修改了个文档.官方Wiki : http://kafka.apache.org/quickstart 快速开始 本教程假定您正在开始新鲜,并且没有现有的 ...

  7. PHP字符串函数-trim()实例用法

    string trim ( string $str [, string $charlist = " \t\n\r\0\x0B" ] )此函数返回字符串 str 去除首尾空白字符后的 ...

  8. I/O输入输出流

    I/O(输入/输出) 在变量.数组和对象中存储的数据是暂时存在的,程序结束后它们就会消失.为了能够永久地保存创建的数据,需要将其保存在磁盘文件中,这样可以在其他程序中使用它们. Java的I/O技术可 ...

  9. 规划自己的生活,从使用GTD时间管理法开始

    前言 为了不再浪费时间,不在茫然度过每一天,我为自己应用了GTD时间管理法,之前并不知道这种方法,实际和我自己定制的也差不太多,下面说说这个方法.   一.GTD时间管理 时间管理法有很多,而GTD( ...

  10. (@WhiteTaken)解决Unity5.x下UnityVS2013不能使用的问题

    终于解决了这一困扰我很久的问题. 下面来介绍一下我遇到的问题: 前段时间,重新做了系统,并且安装了Unity5.6版本,VS2013,UnityVS 2013.msi,Visual Studio 20 ...