美文网首页
MySQL如何避免全表扫描

MySQL如何避免全表扫描

作者: 偏执的工匠 | 来源:发表于2020-03-17 09:04 被阅读0次

MySQL全表扫描在大多数场景下性能都是非常低下的,尤其在表数据量特别大的情况下,全表扫描会耗尽数据库资源,严重时会导致数据库服务不可用,数据库崩溃,因此,业务SQL在发布上线前,应当检查是否会导致全表扫描。

原文地址:
https://mytecdb.com/blogDetail.php?id=104

1. MySQL全表扫描的原因

通过对SQL执行explain,在输出信息中如果type字段为All,那么这个SQL就是走的全表扫描。全表扫描通常由以下原因产生:

  1. 表非常小,全表扫描比走索引有更好的性能。通常这样的表记录数小于10,并且每行记录的数据量也不大。
  2. 在where或者on子句上涉及到的字段,没有可用的索引。
  3. 通过索引字段与常数值进行条件匹配,MySQL优化器基于索引计算出扫描的记录数太多,超过全表记录的30%,优化器认为全表扫描性能将比走索引更好。
  4. 在一个区分度不好的字段上建索引,比如性别,查询男性或者女性,即使在性别字段上建索引,优化器认为走索引性能并不如全表扫描好。

对于记录数比较小的表,全表扫描并不会对性能产生太大的影响,有时候反而会提高性能。但是随着数据量的增加,全表扫描会越来越慢,因此应当尽可能的避免全表扫描。

2. MySQL如何避免全表扫描

有一些方式可以帮助优化器避免使用全表扫描,如下:

  1. 在where条件或者join的连接字段上添加合适的索引,大多数全表扫描是由于忘了加索引导致。
  2. ANALYZE TABLE tbl_name,更新索引分布统计信息,帮助优化器更准确地评估执行成本,产生更优的执行计划。
  3. FORCE INDEX,让MySQL优化器强制走某个索引。
  4. 设置参数--max-seeks-for-key=1000 或者 SET max_seeks_for_key=1000,这个值设置的越小,MySQL优化器越倾向于走索引,而不是全表扫描。

参考资料:
https://dev.mysql.com/doc/refman/5.7/en/table-scan-avoidance.html

相关文章

  • MySQL如何避免全表扫描

    MySQL全表扫描在大多数场景下性能都是非常低下的,尤其在表数据量特别大的情况下,全表扫描会耗尽数据库资源,严重时...

  • mongo索引

       不使用索引的查询称为全表扫描。通常来说,应该尽量避免全表扫描,全表扫描的效率非常低。   创建索引: db....

  • MySQL 数据量超过百万后怎么处理

    原则:避免全表扫描 数据量大的时候,应尽量避免全表扫描,应考虑在 where 及 order by 涉及的列上建立...

  • MySQL 数据量超过百万后怎么处理

    原则:避免全表扫描 数据量大的时候,应尽量避免全表扫描,应考虑在 where 及 order by 涉及的列上建立...

  • MySQL中的SQL的常见优化策略

    1.1 避免全表扫描 对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列...

  • (转)SQL避免全表扫描,SQL 优化

    (转)SQL避免全表扫描,SQL 优化 对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 orde...

  • sql语句优化

    避免全表扫描的sql优化 对查询进行优化,应尽量避免全表扫描,首先应考虑在where 及order by 涉及的列...

  • MySQL中的SQL的常见优化策略

    9.1避免全表扫描 对査询进行优化,应尽量避免全表扫描,首先应考虑在where及order by涉及的列上建立素引...

  • 提高sql语句的查询速度

    where和limit都具有避免全表扫描的功能 (mysql),区别在于:where能够充分利用索引,而limit...

  • 30个MySQL千万级大数据SQL查询优化技巧详解

    数据里的MYSQL使用。 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by ...

网友评论

      本文标题:MySQL如何避免全表扫描

      本文链接:https://www.haomeiwen.com/subject/xfjzehtx.html