MySQL如何避免全表扫描?

MySQL如何避免全表扫描?

这篇文章解释了何时以及为什么MySQL会执行全表扫描来解析查询,以及如何避免在大型表上进行不必要的全表扫描。

何时会发生全表扫描

MySQL使用全表扫描(在EXPLAIN输出中的type列显示为ALL)来解析查询的几种常见情况包括:

  • 表很小,进行表扫描比进行键查找更快。这通常出现在行数少于10行且行长度短的表上。
  • ONWHERE子句中没有可用的索引列的限制条件时。
  • 与常量值比较的索引列覆盖了表的太大部分,MySQL计算后认为表扫描会更快。
  • 使用低基数键(许多行匹配键值)通过另一列。在这种情况下,MySQL认为使用键可能需要许多键查找,而表扫描会更快。

如何避免全表扫描

对于小表,表扫描通常是适当的,对性能的影响可以忽略不计。对于大表,可以尝试以下技术来避免优化器错误地选择表扫描:

  • 使用ANALYZE TABLE tbl_name更新扫描表的键分布。

  • 对被扫描的表使用FORCE INDEX,以告诉MySQL与使用给定索引相比,表扫描的成本非常高:

    sql 复制代码
    SELECT * FROM t1, t2 FORCE INDEX (index_for_column)
      WHERE t1.col_name=t2.col_name;
  • 启动mysqld时使用--max-seeks-for-key=1000选项,或使用SET max_seeks_for_key=1000,告诉优化器假设没有任何键扫描会导致超过1,000次键查找。这可以影响优化器的选择,使其倾向于使用索引而非执行表扫描。

通过应用这些技术,可以减少全表扫描的发生,特别是在处理大型表时,这对于提高查询性能和整体数据库性能是非常重要的。

相关推荐
一只小bit2 小时前
MySQL事务:如何保证ACID?MVCC到底如何工作?
数据库·mysql·oracle
小猪咪piggy2 小时前
【项目】小型支付商城 MVC/DDD
java·jvm·数据库
向阳而生,一路生花2 小时前
redis离线安装
java·数据库·redis
·云扬·2 小时前
使用pt-archiver实现MySQL数据归档与清理的完整实践
数据库·mysql
黄焖鸡能干四碗2 小时前
信息安全管理制度(Word)
大数据·数据库·人工智能·智慧城市·规格说明书
zhangyifang_0093 小时前
PostgreSQL一些概念特性
数据库·postgresql
weixin_46683 小时前
安装Zabbix7
数据库·mysql·zabbix
数据库生产实战3 小时前
Oracle 19C实测:重命名分区表后又重命名分区索引,分区索引会失效吗?DBA必看避坑指南!
数据库·oracle·dba
king_harry3 小时前
window server2008下Oracle 配置dblink查询 MySQL 数据
数据库·mysql·oracle·odbc·dblink
chde2Wang3 小时前
hbase启动报错-keeperErrorCode
大数据·数据库·hbase