Mysql学习Mysql索引的类型和优缺点详解
《Mysql学习Mysql索引的类型和优缺点详解》要点: 索引是一种特殊的文件(InnoDB数据表上的索引是表空间的一个组成部分),它们包含着对数据表里所有记录的引用指针. 1. InnoDB数据表的索引 与MyISAM数据表相比,索引对InnoDB数据的重要性要大得多.在InnoDB数据表上,索引对InnoDB数据表的重要性要在得多.在 InnoDB数据表上,索引不仅会在搜索数据记录时发挥作用,还是数据行级锁定机制的苊、基础.”数据行级锁定”的意思是指在事务操作的执行过程中锁定正 在被处理的个别记录,不让其他用户进行访问.这种锁定将影响到(但不限于)SELECT…LOCK IN SHARE MODE、SELECT…FOR UPDATE命令以及INSERT、UPDATE和DELETE命令. 2. 限制 如果WEHERE子句的查询条件里有不等号(WHERE coloum != …),MySQL将无法使用索引. 普通索引、唯一索引和主索引 1. 普通索引 普通索引(由关键字KEY或INDEX定义的索引)的唯一任务是加快对数据的访问速度.因此,应该只为那些最经常出现在查询条件(WHERE column = …)或排序条件(ORDER BY column)中的数据列创建索引.只要有可能,就应该选择一个数据最整齐、最紧凑的数据列(如一个整数类型的数据列)来创建索引. 2. 唯一索引 3. 主索引MYSQL数据库 在前面已经反复多次强调过:必须为主键字段创建一个索引,这个索引就是所谓的”主索引”.主索引与唯一索引的唯一区别是:前者在定义时使用的关键字是 PRIMARY而不是UNIQUE.MYSQL数据库 4. 外键索引 如果为某个外键字段定义了一个外键约束条件,MySQL就会定义一个内部索引来帮助自己以最有效率的方式去管理和使用外键约束条件. 5. 复合索引 索引可以覆盖多个数据列,如像INDEX(columnA,columnB)索引.这种索引的特点是MySQL可以有选择地使用一个这样的索引.如果查询操作只需要用到columnA数据列上的一个索引,就可以使 用复合索引INDEX(columnA,columnB).不过,这种用法仅适用于在复合索引中排列在前的数据列组合.比如说,INDEX(A,B,C)可以当做A或(A,B)的索引来使用,但不能当做B、C或(B,C)的索引来使用. 6. 索引的长度 在为CHAR和VARCHAR类型的数据列定义索引时,可以把索引的长度限制为一个给定的字符个数(这个数字必须小于这个字段所允许的最大字符个数).这 么做的好处是可以生成一个尺寸比较小、检索速度却比较快的索引文件.在绝大多数应用里,数据库中的字符串数据大都以各种各样的名字为主,把索引的长度设置 为10~15个字符已经足以把搜索范围缩小到很少的几条数据记录了. ?? 文本字段上的普通索引只能加快对出现在字段内容最前面的字符串(也就是字段内容开头的字符)进行检索操作.如果字段里存放的是由几个、甚至是多个单词构成 的较大段文字,普通索引就没什么作用了.这种检索往往以LIKE %word%的形式出现,这对MySQL来说很复杂,如果需要处理的数据量很大,响应时间就会很长. 下面这条命令添加: 有了全文索引,就可以用SELECT查询命令去检索那些包含着一个或多个给定单词的数据记录了.下面是这类查询命令的基本语法: 上面这条命令将把column1和column2字段里有word1、word2和word3的数据记录全部查询出来. 注解:InnoDB数据表不支持全文索引. 查询和索引的优化 ????? 只有当数据库里已经有了足够多的测试数据时,它的性能测试结果才有实际参考价值.如果在测试数据库里只有几百条数据记录,它们往往在执行完第一条查询命令 之后就被全部加载到内存里,这将使后续的查询命令都执行得非常快C不管有没有使用索引.只有当数据库里的记录超过了1000条、数据总量也超过了 MySQL服务器上的内存总量时,数据库的性能测试结果才有意义. ????? 在不确定应该在哪些数据列上创建索引的时候,人们从EXPLAIN SELECT命令那里往往可以获得一些帮助.这其实只是简单地给一条普通的SELECT命令加一个EXPLAIN关键字作为前缀而已.有了这个关键 字,MySQL将不是去执行那条SELECT命令,而是去对它进行分析.MySQL将以表格的形式把查询的执行过程和用到的索引(如果有的话)等信息列出 来. possible_keys数据列给出了MySQL在搜索数据记录时可选用的各个索引.key数据列是MySQL实际选用的索引,这个索引按字节计算的长 度在key_len数据列里给出.比如说,对于一个INTEGER数据列的索引,这个字节长度将是4.如果用到了复合索引,在key_len数据列里还可 以看到MySQL具体使用了它的哪些部分.作为一般规律,key_len数据列里的值越小越好(意思是更快). 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家PHP.MYSQL数据库 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |