Mysql中强制索引的具体使用

 更新时间:2023年08月14日 11:02:08   作者:Pisces_224  
Mysql强制索引可以通过强制使用某些列的索引来提高查询的性能,本文就来介绍一下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中explain命令返回参数的具体使用

    Mysql中explain命令返回参数的具体使用

    EXPLAIN返回的关键列包括id、select_type、table、type、possible_keys、key、key_len、ref、rows和Extra等,本文就来介绍Mysql中explain命令返回参数,感兴趣的可以了解一下
    2024-09-09
  • mysql 5.7.18 zip版安装配置方法图文教程(win7)

    mysql 5.7.18 zip版安装配置方法图文教程(win7)

    这篇文章主要为大家详细介绍了win7下mysql 5.7.8 zip版安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • 基于Php mysql存储过程的详解

    基于Php mysql存储过程的详解

    本篇文章是对Php中的mysql存储过程进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • mysql查询结果实现多列拼接查询

    mysql查询结果实现多列拼接查询

    本文主要介绍了mysql查询结果实现多列拼接查询,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • MySQL Innodb行格式详解

    MySQL Innodb行格式详解

    在数据库管理中,行格式是数据存储的重要概念,尤其是在MySQL的InnoDB存储引擎中,本文给大家介绍MySQL Innodb行格式,感兴趣的朋友跟随小编一起看看吧
    2024-09-09
  • 调用MySQL中数据库元数据的方法

    调用MySQL中数据库元数据的方法

    这篇文章主要介绍了调用MySQL中数据库元数据的方法,文中给出了了PHP和Perl脚本下的调用示例,需要的朋友可以参考下
    2015-05-05
  • CentOS7下mysql 8.0.16 安装配置方法图文教程

    CentOS7下mysql 8.0.16 安装配置方法图文教程

    这篇文章主要为大家详细介绍了CentOS7下mysql 8.0.16 安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-05-05
  • phpstudy无法启动MySQL数据库解决方法

    phpstudy无法启动MySQL数据库解决方法

    这篇文章主要给大家介绍了关于phpstudy无法启动MySQL数据库的解决方法,文中通过图文将解决的办法介绍的非常详细,对同样遇到这个问题的同学具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-05-05
  • 关于Mysql5.7及8.0版本索引失效情况汇总

    关于Mysql5.7及8.0版本索引失效情况汇总

    这篇文章主要介绍了关于Mysql5.7及8.0版本索引失效情况汇总,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • MySQL substr函数使用方法详解

    MySQL substr函数使用方法详解

    MySQL substr函数是指从一个内容中,按照指定条件,「截取」一个字符串,这个内容可以是数值或字符串,本文就来给大家讲讲MySQL substr函数的使用方法,需要的朋友可以参考下
    2023-07-07

最新评论