mysql 添加索引后 在查询的时候是mysql就自动从索引里面查询了。还是查询的时候有单 独的参数查询索引?
2015-06-10 11:14
706 查看
MYSQL在创建索引后对索引的使用方式分为两种: 1 由数据库的查询优化器自动判断是否使用索引; 2 用户可在写SQL语句时强制使用索引 下面就两种索引使用方式进行说明 第一种,自动使用索引。数据库在收到查询语句后会查看where语句后面的查询条件,同时查看在表上面有哪些索引,然后根据查询条件和索引进行匹配。 查询条件和索引的匹配包括查询字段与索引字段的匹配和查询类型和索引类型的匹配。前者很好理解,就是查询条件的属性上要建有索引,后者则是说查询条件必须能够使用索引,比如等值判断和范围查询可以使用B+树索引,而hash索引只能适用于等值判断。 在找到与查询条件匹配的索引后,就是进行代价估计来决定是否使用索引,代价估计主要根据要访问的就数量,一般来说如果通过索引访问的记录数量占全表记录数量15%以上,则不会使用索引而是使用全表扫描,因为此时使用索引的代价更大。在大多数情况下使用索引是会提高效率的。 经过优化器的判断,最终会决定是否使用索引 第二种,强制使用索引,主要是通过SQL语句实现的 select * from table force index(PRI) limit 2;(强制使用主键) select * from table force index(ziduan1_index) limit 2;(强制使用索引"ziduan1_index") select * from table force index(PRI,ziduan1_index) limit 2;(强制使用索引"PRI和ziduan1_index") 也可以禁止索引的使用 select * from table ignore index(PRI) limit 2;(禁止使用主键) select * from table ignore index(ziduan1_index) limit 2;(禁止使用索引"ziduan1_index") select * from table ignore index(PRI,ziduan1_index) limit 2;(禁止使用索引"PRI,ziduan1_index")
相关文章推荐
- 【MySql】存储过程限定月份,限定某天等基础的使用
- MySQL用户管理和权限设置
- mysql的授权问题
- replace into 浅析之二
- replace into 浅析之一
- (DBA之路【五】)关于锁的故事
- PB如何连接mysql数据库
- 查询mysql当前连接数
- MYSQL使用group by时,查询结果的总记录数
- Mac下修改Mysql数据库密码,忘记密码
- mysql 用户管理和权限设置
- 语法:MySQL中INSERT IGNORE INTO和REPLACE INTO的使用
- MySQL的错误码
- MySQL执行计划解读
- MySQL查询本周、上周、本月、上个月份数据的sql代码
- MySQL数据库学习一 数据库概述
- ubuntu安装mysql的时候报 hash 校验和不符的解决方法
- mysqldump 使用–single-transaction
- MySQL存储过程
- (DBA之路【六】)mysql锁的全解-比较实例化的一篇文章