Mysql中强制索引的具体使用
强制索引
强制索引,即指定本次查询使用某个特定的索引,这样就可避免MySQL优化器使用低效的索引或者走全表扫描放弃使用索引。
(Mysql的优化器并不完全可靠~)
使用
sql查询语句中加上force index(索引名)
select * from salaries force index(idx_emp_no ) where emp_no=10005
题外话
- 忽略索引
select * from 表名 ignore index(索引名) where …
- 关闭缓存
select SQL_NO_CACHE * from 表名
- 强制缓存
select SQL_CACHE * from 表名 ignore index(索引名) where …
- 优先操作 HIGH_PRIORITY
- 滞后操作 LOW_PRIORITY
- 延时插入 INSERT DELAYED
- 强制连接顺序 STRAIGHT_JOIN
- 强制使用临时表 SQL_BUFFER_RESULT
- 分组使用临时表 SQL_BIG_RESULT和SQL_SMALL_RESULT
哪些情况适合建立索引
1、 频繁作为where条件语句查询的字段
2、关联字段需要建立索引,例如外键字段,student表中的classid, classes表中的schoolid 等
3、 排序字段可以建立索引
4、 分组字段可以建立索引,因为分组的前提是排序
5、统计字段可以建立索引,例如count(),max()
哪些情况不适合建立索引
- 频繁更新的字段不适合建立索引
- where条件中用不到的字段不适合建立索引
- 表数据可以确定比较少的不需要建索引
- 数据重复且发布比较均匀的的字段不适合建索引(唯一性太差的字段不适合建立索引),例如性别,真假值
- 参与列计算的列不适合建索引
到此这篇关于Mysql中强制索引的具体使用的文章就介绍到这了,更多相关Mysql 强制索引内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
MySql 8.0.11-Winxp64(免安装版)配置教程
这篇文章主要介绍了MySql 8.0.11-Winxp64(免安装版)配置教程,非常不错,具有参考借鉴价值,需要的朋友参考下吧2018-05-05
mysql存储过程之引发存储过程中的错误条件(SIGNAL和RESIGNAL语句)实例分析
这篇文章主要介绍了mysql存储过程之引发存储过程中的错误条件(SIGNAL和RESIGNAL语句),结合实例形式分析了mysql使用SIGNAL和RESIGNAL语句来引发存储过程中的错误条件相关操作技巧与注意事项,需要的朋友可以参考下2019-12-12
SQL HAVING子句在GROUP BY中的条件筛选灵活运用
这篇文章主要为大家介绍了SQL HAVING子句在GROUP BY中的条件筛选灵活运用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-11-11


最新评论