MySQL如何避免全表扫描

MySQL全表扫描可能导致性能低下,特别是在大数据量时。全表扫描常见于无索引、索引效率低等情况。避免全表扫描的方法包括在关键字段添加索引、更新索引统计、使用FORCE INDEX及调整max_seeks_for_key参数。
摘要由CSDN通过智能技术生成

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如何避免全表扫描

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值