首页 > 代码库 > MySQL索引的设计和使用
MySQL索引的设计和使用
一、索引可以有效地提升SELECT操作的性能,同时会影响UPDATE、CREATE和DELETE操作的性能。每种引擎对于表的索引有数量和长度的限制。
二、索引的设计原则
(A) 搜索的索引列,不一定是要选择的列,最适合索引的列是where子句的列或连接子句中的列。
(B) 使用唯一索引,索引列的基础越大,索引的效果越好。
(C) 使用短索引,如果对字符串列(char,varchar,text)索引,应该指定前缀长度,使用前缀索引。
(D) 利用最左前缀,创建一个n列的索引时,实际是创建了MySQL可利用的n个索引。可利用索引中的最左边的列集来匹配行,这样的列集被称为最左前缀。
(E) 不要过度索引,
(F) 对于InnoDB存储引擎的表,记录默认先后会以 主键、唯一索引、内部列 依次存放,选择好的主键很重要。同时,普通索引会保存主键的键值,主键要尽可能选择短的数据类型。
三、BTREE索引和HASH索引
(A) HASH索引的特点:
只用于=和<=>操作符的等式比较。
优化器不能使用HASH索引来加速ORDER BY 操作。
MySQL不能确定两个值之间大约有多少行。
只能使用整个关键词来搜索一行。
(B) BTREE索引的特点
使用 >、<、>=、<=、BETWEEN、!=或者<>,或者LIKE ‘pattern‘(不以通配符开始)操作符时,都可以使用索引。
四、小结
大多数MySQL索引使用BTREE中存储,空间列类型的索引使用RTREE。
MySQL索引的设计和使用
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。