MySQL 索引详解
核心提示:本文先容了数据库索引,及其优、缺点。针对MySQL索引的特点、利用进行了具体的描写。分析了如何避免MySQL没法使用,如何使用EXPLAIN分析查询语句,如何优化MySQL索引的利用。
本文先容了数据库索引,及其优、缺点。针对MySQL索引的特点、利用进行了具体的描写。分析了如何避免MySQL没法使用,如何使用EXPLAIN分析查询语句,如何优化MySQL索引的利用。
索引是1种特殊的文件(InnoDB数据表上的索引是表空间的1个组成部份),它们包括着对数据表里所有记录的援用指针。
注:
[1]索引不是万能的!
索引可以加快数据检索操纵,但会使数据修改操纵变慢。每修改数据记录,索引就必须刷新1次。为了在某种程序上弥补这1缺点,很多SQL命令都有1个DELAY_KEY_WRITE项。这个选项的作用是暂时制止MySQL在该命令每插进1条新记录和每修改1条现有以后立即对索引进行刷新,对索引的刷新将等到全部记录插进/修改终了以后再进行。在需要把很多新记录插进某个数据表的场合,DELAY_KEY_WRITE选项的作用将非常明显。
[2]另外,索引还会在硬盘上占用相当大的空间。
因此应当只为最常常查询和最常常排序的数据列建立索引。留意,假设某个数据列包括很多重复的内容,为它建立索引就没有太大的实际效果。
从理论上讲,完全可以为数据表里的每个字段分别建1个索引,但MySQL把同1个数据表里的索引总数限制为16个。
1. InnoDB数据表的索引
与MyISAM数据表相比,索引对InnoDB数据的重要性要大很多。在InnoDB数据表上,索引对InnoDB数据表的重要性要在很多。在 InnoDB数据表上,索引不但会在搜索数据记录时发挥作用,还是数据行级锁定机制的苊、基础。”数据行级锁定”的意思是指在事务操纵的履行进程中锁定正在被处理的个别记录,不让其他用户进行访问。这类锁定将影响到(但不限于)SELECT…LOCK IN SHARE MODE、SELECT…FOR UPDATE命令和INSERT、UPDATE和DELETE命令。
出于效率方面的考虑,InnoDB数据表的数据行级锁定实际产生在它们的索引上,而不是数据表本身上。明显,数据行级锁定机制只有在有关的数据表有1个合适的索引可供锁定的时候才能发挥效率。
2. 限制
假设WEHERE子句的查询条件里有不等号(WHERE coloum != …),MySQL将没法使用索引。
类似地,假设WHERE子句的查询条件里使用了函数(WHERE DAY(column) = …),MySQL也将没法使用索引。
在JOIN操纵中(需要从多个数据表提取数据时),MySQL只有在主键和外键的数据类型相同时才能使用索引。
假设WHERE子句的查询条件里使用比较操纵符LIKE和REGEXP,MySQL只有在搜索模板的第1个字符不是通配符的情况下才能使用索引。比如说,假设查询条件是LIKE ‘abc%’,MySQL将使用索引;假设查询条件是LIKE ‘%abc’,MySQL将不使用索引。
在ORDER BY操纵中,MySQL只有在排序条件不是1个查询条件表达式的情况下才使用索引。(固然如此,在触及多个数据表查询里,即使有索引可用,那些索引在加快ORDER BY方面也没甚么作用)
假设某个数据列里包括很多重复的值,就算为它建立了索引也不会有很好的效果。比如说,假设某个数据列里包括的净是些诸如”0/1″或”Y/N”等值,就没有必要为它创建1个索引。
1 2 3 4 下1页
核心提示:本文先容了数据库索引,及其优、缺点。针对MySQL索引的特点、利用进行了具体的描写。分析了如何避免MySQL没法使用,如何使用EXPLAIN分析查询语句,如何优化MySQL索引的利用。
普通索引、唯1索引和主索引
1. 普通索引
普通索引(由关键字KEY或INDEX定义的索引)的唯1任务是加快对数据的访问速度。因此,应当只为那些最常常出现在查询条件(WHERE column = …)或排序条件(ORDER BY column)中的数据列创建索引。只要有可能,就应当选择1个数据最整洁、最紧凑的数据列(如1个整数类型的数据列)来创建索引。
2. 唯1索引
普通索引答应被索引的数据列包括重复的值。比如说,由于人有可能同名,所以同1个姓名在同1个”员工个人资料”数据表里可能出现两次或更屡次。
假设能肯定某个数据列将只包括彼此各不相同的值,在为这个数据列创建索引的时候就应当用关键字UNIQUE把它定义为1个唯1索引。这么做的好处:1是简化了MySQL对这个索引的治理工作,这个索引也因此而变得更有效率;2是MySQL会在有新记录插进数据表时,自动检查新记录的这个字段的值是否是已在某个记录的这个字段里出现过了;假设是,MySQL将拒尽插进那条新记录。也就是说,唯1索引可以保证数据记录的唯1性。事实上,在很多场合,人们创建唯1索引的目的常常不是为了进步访问速度,而只是为了不数据出现重复。
3. 主索引
在前面已反复屡次夸大过:必须为主键字段创建1个索引,这个索引就是所谓的”主索引”。主索引与唯1索引的唯1辨别是:前者在定义时使用的关键字是PRIMARY而不是UNIQUE。
4. 外键索引
假设为某个外键字段定义了1个外键束缚条件,MySQL就会定义1个内部索引来帮助自己以最有效率的方式往治理和使用外键束缚条件。
5. 复合索引
索引可以覆盖多个数据列,如像INDEX(columnA, columnB)索引。这类索引的特点是MySQL可以有选择地使用1个这样的索引。假设查询操纵只需要用到columnA数据列上的1个索引,便可以够使用复合索引INDEX(columnA, columnB)。不过,这类用法仅适用于在复合索引中排列在前的数据列组合。比如说,INDEX(A, B, C)可以当作A或(A, B)的索引来使用,但不能当作B、C或(B, C)的索引来使用。
上1页 1 2 3 4 下1页
核心提示:本文先容了数据库索引,及其优、缺点。针对MySQL索引的特点、利用进行了具体的描写。分析了如何避免MySQL没法使用,如何使用EXPLAIN分析查询语句,如何优化MySQL索引的利用。
6. 索引的长度
在为CHAR和VARCHAR类型的数据列定义索引时,可以把索引的长度限制为1个给定的字符个数(这个数字必须小于这个字段所答应的最大字符个数)。这么做的好处是可以天生1个尺寸比较小、检索速度却比较快的索引文件。在尽大多数利用里,数据库中的字符串数据大都以各种各样的名字为主,把索引的长度设置为10~15个字符已足以把搜索范围缩小到很少的几条数据记录了。
在为BLOB和TEXT类型的数据列创建索引时,必须对索引的长度做出限制;MySQL所答应的最大索引长度是255个字符。
全文索引
文本字段上的普通索引只能加快对出现在字段内容最前面的字符串(也就是字段内容开头的字符)进行检索操纵。假设字段里寄存的是由几个、乃至是多个单词构成的较大段文字,普通索引就没甚么作用了。这类检索常常以LIKE %word%的情势出现,这对MySQL来讲很复杂,假设需要处理的数据量很大,响应时间就会很长。
这类场合正是全文索引(full-text index)可以大显身手的地方。在天生这类类型的索引时,MySQL将把在文本中出现的所有单词创建为1份清单,查询操纵将根据这份清单往检索有关的数据记录。全文索引即可以随数据表1同创建,也能够等往后有必要时再使用下面这条命令添加:ALTER TABLE tablename ADD FULLTEXT(column1, column2) 有了全文索引,便可以够用SELECT查询命令往检索那些包括着1个或多个给定单词的数据记录了。
下面是这类查询命令的基本语法:
SELECT * FROM tablename WHERE MATCH(column1, column2) AGAINST(’word1′, ‘word2′, ‘word3′) |
上面这条命令将把column1和column2字段里有word1、word2和word3的数据记录全部查询出来。
注解:InnoDB数据表不支持全文索引。
上1页 1 2 3 4 下1页
核心提示:本文先容了数据库索引,及其优、缺点。针对MySQL索引的特点、利用进行了具体的描写。分析了如何避免MySQL没法使用,如何使用EXPLAIN分析查询语句,如何优化MySQL索引的利用。
查询和索引的优化
只有当数据库里已有了足够多的测试数据时,它的性能测试结果才有实际参考价值。假设在测试数据库里只有几百条数据记录,它们常常在履行完第1条查询命令以后就被全部加载到内存里,这将使后续的查询命令都履行得非常快–不管有无使用索引。只有当数据库里的记录超过了1000条、数据总量也超过了 MySQL服务器上的内存总量时,数据库的性能测试结果才故意义。
在不肯定应当在哪些数据列上创建索引的时候,人们从EXPLAIN SELECT命令那里常常可以取得1些帮助。这实在只是简单地给1条普通的SELECT命令加1个EXPLAIN关键字作为前缀而已。有了这个关键字,MySQL将不是往履行那条SELECT命令,而是往对它进行分析。MySQL将以表格的情势把查询的履行进程和用到的索引(假设有的话)等信息列出来。
在EXPLAIN命令的输出结果里,第1列是从数据库读取的数据表的名字,它们按被读取的前后顺序排列。type列指定了本数据表与其它数据表之间的关联关系(JOIN)。在各种类型的关联关系当中,效率最高的是system,然后顺次是const、eq_ref、ref、range、index和 All(All的意思是:对应于上1级数据表里的每1条记录,这个数据表里的所有记录都必须被读取1遍–这类情况常常可以用1索引来避免)。
possible_keys数据列给出了MySQL在搜索数据记录时可选用的各个索引。key数据列是MySQL实际选用的索引,这个索引按字节计算的长度在key_len数据列里给出。比如说,对1个INTEGER数据列的索引,这个字节长度将是4。假设用到了复合索引,在key_len数据列里还可以看到MySQL具体使用了它的哪些部份。作为1般规律,key_len数据列里的值越小越好(意思是更快)。
ref数据列给出了关联关系中另1个数据表里的数据列的名字。row数据列是MySQL在履行这个查询时预计会从这个数据表里读出的数据行的个数。row数据列里的所有数字的乘积可让我们大致了解这个查询需要处理多少组合。
最后,extra数据列提供了与JOIN操纵有关的更多信息,比如说,假设MySQL在履行这个查询时必须创建1个临时数据表,就会在extra列看到using temporary字样。
本文摘自《MySQL 5权威指南》(3rd)的8.9节。(2007.07.05最后更新)
上1页 1 2 3 4 唐山网站建设www.fw8.netTAG:数据,命令,字段,索引,数据表
评论加载中...
|