广告
返回顶部
首页 > 资讯 > 数据库 >MySQL慢查询以及重构查询的方式记录
  • 474
分享到

MySQL慢查询以及重构查询的方式记录

2024-04-02 19:04:59 474人浏览 安东尼
摘要

前言 什么是慢查询,如何优化慢查询,下面介绍这两个知识点的相关知识。 慢查询基础:优化数据访问 是否向数据库请求了不需要的数据 查询不需要的记录:解决方案:查询后面加上Limit

前言

什么是慢查询,如何优化慢查询,下面介绍这两个知识点的相关知识。

慢查询基础:优化数据访问

是否向数据库请求了不需要的数据

查询不需要的记录:解决方案:查询后面加上Limit

多表关联时返回全部列:解决方案:只取需要的列

总是取出全部列:select * 解决方案:最好还是获取部分列,除非应用程序处缓存列的数据了

重复查询相同的数据:解决方案:需要时从缓存中取出

MySQL是否在扫描额外的记录

可以从响应时间,扫描的行数,返回的行数来进行查询开销的衡量。

要想减少扫描行数可以使用索引对需要的记录进行覆盖,但是增加索引不意味着就能让扫描的行数等于返回的行数,比如sum,count之类的聚合函数

重构查询的方法

一个复杂查询还是多个简单查询

在过去,总是强调需要数据库层完成尽可能多的工作,因为过去网络通信查询解析和优化是一件代价很高的事情。

但是这样的想法对于Mysql并不适用,mysql从设计上让连接和断开连接都很轻量级,在返回一个小的查询结果方面很高效。现代的网络速度比以前要快很多,无论是带宽还是延迟。在某些版本的Mysql上,即使在一个通用服务器上,也能够运行每秒超过10万的查询,即使是一个千兆网卡也能轻松满足每秒超过2000次的查询。所以运行多个小查询现在已经不是大问题了。

当然,相比较于内部扫描,响应数据给客户端更加耗时,所以在同条件下,使用尽可能少的查询更好。

切分查询

当使用sql进行查询时,需要注意将大查询切分成小查询,可以减少对数据库的影响,因为一个大语句一次性完成的话,则可能一次住很多数据,占满整个事务日志,耗尽系统资源,阻塞其他查询。

比如我们做数据统计时要对大量订单号的信息进行查询,那么是一次性用in查询,还是切割参数list多次查询呢,答案是切割参数list多次查询,因为当in里面的参数过多时,MySQL就会认为再走索引已经不行了,可能就会进行全表查询,如果这个时候数据表数据量过大,那可能就会造成查询超时。


// chops a list into non-view sublists of length L
static <T> List<List<T>> chopped(List<T> list, final int L) {
    List<List<T>> parts = new ArrayList<List<T>>();
    final int N = list.size();
    for (int i = 0; i < N; i += L) {
        parts.add(new ArrayList<T>(
            list.subList(i, Math.min(N, i + L)))
        );
    }
    return parts;
}
List<Integer> numbers = Collections.unmodifiableList(
    Arrays.asList(5,3,1,2,9,5,0,7)
);
List<List<Integer>> parts = chopped(numbers, 3);
System.out.println(parts); // prints "[[5, 3, 1], [2, 9, 5], [0, 7]]"
parts.get(0).add(-1);
System.out.println(parts); // prints "[[5, 3, 1, -1], [2, 9, 5], [0, 7]]"
System.out.println(numbers); // prints "[5, 3, 1, 2, 9, 5, 0, 7]" (unmodified!)

在程序中将list截断,从而使查询能使用索引而不是进行全表扫描。

阿里开发手册中就推荐仔细评估in后面的集合元素数量,控制在1000个之内。

分解关联查询

将多表inner join 进行分解,分解成小查询,超过三个表的join,就需要禁止了。

优点有:

  1. 缓存的效率会更高,
  2. 分解后的查询可以减少锁的竞争
  3. 应用层可以缓存查询数据,减小数据库的压力。
  4. 可以提升查询效率,因为用主键之类进行in查询,比按照条件范围查询可能会更高效,尤其是大表的时候。
  5. 可以减少冗余记录的查询
  6. 更进一步,这样做相当于在应用中实现了哈希关联,而不是使用MySQL的嵌套循环关联。某些场景哈希关联的效率要高很多。

总结

到此这篇关于MySQL慢查询以及重构查询的文章就介绍到这了,更多相关MySQL慢查询重构查询内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL慢查询以及重构查询的方式记录

本文链接: https://www.lsjlt.com/news/128314.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL慢查询以及重构查询的方式记录
    前言 什么是慢查询,如何优化慢查询,下面介绍这两个知识点的相关知识。 慢查询基础:优化数据访问 是否向数据库请求了不需要的数据 查询不需要的记录:解决方案:查询后面加上Limit...
    99+
    2022-11-12
  • mysql查询连续记录方式
    目录案例解决思路1.对满足初次查询的数据赋予一个自增列b2.用自增的id减去自增列b3.对等差列c分组, 并将分组的id组装起来4.根据组装的id去找数据总结建议案例 最近遇到一个业...
    99+
    2022-11-13
  • mysql构造慢查询的方法
    这篇文章将为大家详细讲解有关mysql构造慢查询的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。mysql构造慢查询的方法:1、修改配置文件,在【my.ini】增加相...
    99+
    2022-10-18
  • MySQL慢查询以及解决方案详解
    目录一、前言二、慢查询2.1 什么是慢查询?2.2 慢查询配置1、慢查询日志2、未使用索引是否开启日志3、慢查询时间设置4、慢查询路径三、慢查询日志分析3.1 mysqldumpslow工具四、慢查询解决方案4.1 索引...
    99+
    2023-05-05
    mysql慢查询解决方案 mysql 慢查询 mysql 慢sql查询
  • MYSQL慢查询日志的查看方式
    这篇文章主要介绍“MYSQL慢查询日志的查看方式”,在日常操作中,相信很多人在MYSQL慢查询日志的查看方式问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MYSQL慢查询日志...
    99+
    2022-10-18
  • MySQL中的流式查询及游标查询方式
    目录一、业务场景二、罗列一下三种处理方式2.1 常规查询2.2 流式查询2.3 游标查询三、RowData3.1 RowDataStatic3.2 RowDataDynamic3.3 RowDataCursor四、JDB...
    99+
    2022-08-17
    MySQL查询 流式查询 游标查询 MySQL游标
  • MySQL中慢查询记录的原理是什么
    本篇文章给大家分享的是有关MySQL中慢查询记录的原理是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 一、慢查询中的时间 实际...
    99+
    2022-10-18
  • mysql的慢查询日志记录哪些内容
    本篇内容主要讲解“mysql的慢查询日志记录哪些内容”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql的慢查询日志记录哪些内容”吧! ...
    99+
    2022-10-19
  • MySQL中查询、删除重复记录的方法大全
      前言 本文主要给大家介绍了关于MySQL中查询、删除重复记录的方法,分享出来供大家参考学习,下面来看看详细的介绍: 查找所有重复标题的记录: 1 select title,count(*) as cou...
    99+
    2018-05-22
    MySQL中查询 删除重复记录的方法大全
  • MySQL中查询、删除重复记录的方法大全
    前言本文主要给大家介绍了关于MySQL中查询、删除重复记录的方法,分享出来供大家参考学习,下面来看看详细的介绍:查找所有重复标题的记录:select title,count(*) as count&n...
    99+
    2022-08-10
    MySQL 查询 删除
  • MySQL中流式查询及游标查询的方式是什么
    这篇文章主要讲解了“MySQL中流式查询及游标查询的方式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL中流式查询及游标查询的方式是什么”吧!...
    99+
    2022-10-19
  • mysql查询前20条记录的方法
    小编给大家分享一下mysql查询前20条记录的方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!mysql查询前20条记录的方法:执行【select * from no_primar...
    99+
    2022-10-18
  • Mysql查询以某"字符串"开头的查询方式
    目录Mysql查询以某"字符串"开头的查询查询不以某个或者某些字符串为开头的字符串查询以某个或者某些字符串为开头的字符串Mysql查询条件字符串类型 = 0假如有...
    99+
    2022-11-13
  • mysql查询最新5条记录的方法
    小编给大家分享一下mysql查询最新5条记录的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!mysql查询最新的5条记录的方...
    99+
    2022-10-18
  • Mysql常见的慢查询优化方式总结
    目录前言(1)数据库中设置SQL慢查询(2)分析慢查询日志         (3)常见的慢查询优化总结前言 这篇文章主要是就在公司实习的时候,对SQL优化工作作出的一些整...
    99+
    2023-05-05
    mysql如何优化查询 慢查询sql语句优化 MySQL查询优化
  • Mysql的主要几种日志及慢查询方法
    本文主要给大家简单讲讲Mysql的主要几种日志及慢查询方法,相关专业术语大家可以上网查查或者找一些相关书籍补充一下,这里就不涉猎了,我们就直奔主题吧,希望Mysql的主要几种日志及慢查询方法这篇文章可以给大...
    99+
    2022-10-18
  • Mysql查询以某&quot;字符串&quot;开头的查询方式
    目录mysql查询以某"字符串"开头的查询查询不以某个或者某些字符串为开头的字符串查询以某个或者某些字符串为开头的字符串Mysql查询条件字符串类型 = 0假如有表AA表中有以下数据Mysql查询以某...
    99+
    2022-08-29
  • mysql查询每个表有多少条记录的方法
    mysql查询每个表有多少条记录的方法?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!mysql查询每个表有多少条记录的方法...
    99+
    2022-10-18
  • mysql和mssql以及oracle的分页查询方法介绍
    本篇内容介绍了“mysql和mssql以及oracle的分页查询方法介绍”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能...
    99+
    2022-10-18
  • 详细聊一聊mysql的树形结构存储以及查询
    目录序存储parent存储pathMPTT(Modified Preorder Tree Traversal)小结doc序 本文主要研究一下mysql的树形结构存储及查询 存储par...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作