MySQL慢SQL语句常见诱因以及解决方法

作者:哈天奇不奇 时间:2024-01-18 12:36:25 

1. 无索引、索引失效导致慢查询

如果在一张几千万数据的表中以一个没有索引的列作为查询条件,大部分情况下查询会非常耗时,这种查询毫无疑问是一个慢SQL查询。所以对于大数据量的查询,需要建立适合的索引来优化查询。

虽然很多时候建立了索引,但在一些特定的场景下,索引还有可能会失效,所以索引失效也是导致慢查询的主要原因之一。

2. 锁等待

常用的存储引擎有 InnoDB 和 MyISAM,前者支持行锁和表锁,后者只支持表锁。

如果数据库操作是基于表锁实现的,试想下,如果一张订单表在更新时,需要锁住整张表,那么其它大量数据库操作(包括查询)都将处于等待状态,这将严重影响到系统的并发性能。

这时,InnoDB 存储引擎支持的行锁更适合高并发场景。但在使用 InnoDB 存储引擎时,要特别注意行锁升级为表锁的可能。在批量更新操作时,行锁就很可能会升级为表锁。

MySQL认为如果对一张表使用大量行锁,会导致事务执行效率下降,从而可能造成其它事务长时间锁等待和更多的锁冲突问题发生,致使性能严重下降,所以MySQL会将行锁升级为表锁。还有,行锁是基于索引加的锁,如果在更新操作时,条件索引失效,那么行锁也会升级为表锁。

因此,基于表锁的数据库操作,会导致SQL阻塞等待,从而影响执行速度。在一些更新操作(insert\update\delete)大于或等于读操作的情况下,MySQL不建议使用MyISAM存储引擎。

除了锁升级之外,行锁相对表锁来说,虽然粒度更细,并发能力提升了,但也带来了新的问题,那就是死锁。因此,在使用行锁时,要注意避免死锁。

3. 不恰当的SQL语句

使用不恰当的SQL语句也是慢SQL最常见的诱因之一。例如,习惯使用<SELECT *>,<SELECT COUNT(*)> SQL语句,在大数据表中使用<LIMIT M,N>分页查询,以及对非索引字段进行排序等等。

来源:https://www.cnblogs.com/agilestyle/p/11429037.html

标签:MySQL,SQL,诱因
0
投稿

猜你喜欢

  • Python中and和or如何使用

    2022-04-27 18:01:49
  • Christopher Schmitt 谈学习CSS的益处

    2008-07-13 14:15:00
  • 让javascript加载速度倍增的方法(解决JS加载速度慢的问题)

    2024-04-19 11:03:22
  • python argparse模块传参用法实例

    2022-01-19 09:53:42
  • win10下MySQL 8.0登录Access denied for user‘root’@‘localhost’ (using password: YES)问题的解决方法

    2024-01-19 05:31:09
  • python采用django框架实现支付宝即时到帐接口

    2023-07-16 00:15:33
  • python的继承知识点总结

    2022-12-10 11:21:28
  • 从零开始写jQuery框架

    2008-12-24 13:37:00
  • canvas学习之API整理笔记(一)

    2024-04-10 10:54:24
  • Git如何合并多次提交

    2023-03-27 13:05:03
  • MySQL架构设计思想详解

    2024-01-24 10:21:13
  • Python 字符串操作(string替换、删除、截取、复制、连接、比较、查找、包含、大小写转换、分割等)

    2021-01-12 08:30:45
  • turtle的基础使用之python turtle递归绘图

    2023-04-25 23:36:08
  • 利用python实现在微信群刷屏的方法

    2023-05-01 13:56:29
  • mysql prompt的用法详解

    2024-01-28 07:30:32
  • Python 制作查询商品历史价格的小工具

    2021-10-13 06:03:16
  • node.js入门教程迷你书、node.js入门web应用开发完全示例

    2024-05-03 15:57:38
  • 详解vue3中组件的非兼容变更

    2024-04-28 09:23:04
  • Django+Celery实现动态配置定时任务的方法示例

    2021-06-11 13:56:19
  • 详解MySQL日期 字符串 时间戳互转

    2024-01-16 15:27:11
  • asp之家 网络编程 m.aspxhome.com