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 8.0.11-Winxp64(免安装版)配置教程

    MySql 8.0.11-Winxp64(免安装版)配置教程

    这篇文章主要介绍了MySql 8.0.11-Winxp64(免安装版)配置教程,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2018-05-05
  • 浅谈mysql的timestamp存在的时区问题

    浅谈mysql的timestamp存在的时区问题

    本文主要介绍了浅谈mysql的timestamp存在的时区问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • mysql存储过程之引发存储过程中的错误条件(SIGNAL和RESIGNAL语句)实例分析

    mysql存储过程之引发存储过程中的错误条件(SIGNAL和RESIGNAL语句)实例分析

    这篇文章主要介绍了mysql存储过程之引发存储过程中的错误条件(SIGNAL和RESIGNAL语句),结合实例形式分析了mysql使用SIGNAL和RESIGNAL语句来引发存储过程中的错误条件相关操作技巧与注意事项,需要的朋友可以参考下
    2019-12-12
  • MySQL 从一张表update字段到另外一张表中

    MySQL 从一张表update字段到另外一张表中

    使用MySQL 4.0版或更高更新您可以通过加入两个或多个表一起一表;通过加入两个表连同您可以更新一个表的记录在相关领域的总部设在另一个表。
    2015-09-09
  • Mysql基础入门 轻松学习Mysql命令

    Mysql基础入门 轻松学习Mysql命令

    这篇文章主要是Mysql基础入门教程,教大家如何轻松学习Mysql命令,并熟练掌握Mysql命令,感兴趣的小伙伴们可以参考一下
    2015-11-11
  • MySQL数据库数据删除操作详解

    MySQL数据库数据删除操作详解

    本文我们将要学习的是作为删除数据使用的 “DELETE” 语句,“DELETE” 语句是用来删除数据的,它不能用来删除数据表本身。删除数据表使用的是 “DROP” 语句,而 “DELETE” 的作用只是用来删除记录而已
    2022-08-08
  • MySQL的事务机制与并发读异常示例详解

    MySQL的事务机制与并发读异常示例详解

    数据库事务是一组数据库操作,它们被视为一个单独的工作单元,要么全部成功,要么全部失败,这篇文章主要介绍了MySQL事务机制与并发读异常的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-11-11
  • mYsql日期和时间函数不求人

    mYsql日期和时间函数不求人

    mYsql日期和时间函数不求人...
    2007-04-04
  • mysql.help_topic生成序列的方法实现

    mysql.help_topic生成序列的方法实现

    本文探讨了如何使用MySQL的help_topic表生成序列,并介绍了相应的SQL查询语句和实现方法,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • SQL HAVING子句在GROUP BY中的条件筛选灵活运用

    SQL HAVING子句在GROUP BY中的条件筛选灵活运用

    这篇文章主要为大家介绍了SQL HAVING子句在GROUP BY中的条件筛选灵活运用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11

最新评论