博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL 的 count(*) 的优化,获取千万级数据表的总行数
阅读量:4292 次
发布时间:2019-05-27

本文共 1020 字,大约阅读时间需要 3 分钟。

Java芋道源码 2019-04-12 21:44:23

  • 一、前言
  • 二、关于count的优化
  • 三、使用explain获取行数
  • 1、关于explain
  • 2、关于返回值

一、前言

这个问题是今天朋友提出来的,关于查询一个1200w的数据表的总行数,用count(*)的速度一直提不上去。找了很多优化方案,最后另辟蹊径,选择了用explain来获取总行数。

二、关于count的优化

网上关于count()优化的有很多。博主这边的思路就是没索引的就建立索引关系,然后使用count(1)或者count()来提升速度。这两个函数默认使用的是数据表中最短的那个索引字段。我朋友这边因为表中只有一个索引字段,所以使用count(1)和count()没什么区别。

MySQL中聚合函数count的使用和性能优化

(https://blog.csdn.net/lmy86263/article/details/73681633)

mysql count(*) 会选哪个索引?

(https://blog.csdn.net/zbdba/article/details/47753721)

大家可以参考这两个博客,都挺不错的。

三、使用explain获取行数

1、关于explain

关于explain,使用mysql的都知道,这个函数是专门用于查看sql语句的执行效率的,网上可供参考的文章很多。

定义: explain 命令速度很快,因为 explain 用并不真正执行查询,而是查询优化器【估算】的行数。

我们使用explain之后,会看到返回很多参数,其中:

rows:显示MySQL认为它执行查询时必须检查的行数。就是这个东西了,既然我们要获取的是数据表的行数,那么可以使用:

MySQL 的 count(*) 的优化,获取千万级数据表的总行数

 

2、关于返回值

以前博主也没注意过返回值的问题,都是直接通过phpmyadmin来查看sql的执行效率。这次因为要用到rows的值,所以就打印了一下,原来这个explain函数是会返回一个数组。这样我们就能通过这个数组获取到我们需求的rows。

MySQL 的 count(*) 的优化,获取千万级数据表的总行数

 

这里直接获取这个值即可。速度极快。原来查询速度是2.33s,换成只用explain之后,速度仅为0008s,提升十分巨大。

来源:http://t.cn/EiT4hjx


搜索微信号(ID:芋道源码),可以获得各种 Java 源码解析。

并且,回复【书籍】后,可以领取笔者推荐的各种 Java 从入门到架构的书籍。

MySQL 的 count(*) 的优化,获取千万级数据表的总行数

来吧,骚年~

你可能感兴趣的文章
jq使用教程06_数据更新日志
查看>>
jq使用教程07_ JQData HTTP 接口正式上线
查看>>
jq使用教程08_基于估值波动周期的择时策略
查看>>
海龟交易法则14_掌控心魔
查看>>
海龟交易法则15_万事俱备
查看>>
海龟交易法则16_附原版海龟交易法则
查看>>
克罗谈投资策略01_期货交易中的墨菲法则
查看>>
克罗谈投资策略02_赢家和输家
查看>>
克罗谈投资策略03_你所期望的赌博方式
查看>>
克罗谈投资策略04_感觉与现实
查看>>
克罗谈投资策略05_涨势买入,跌势卖出
查看>>
通向财务自由之路01_导读
查看>>
通向财务自由之路02_成功的决定因素:你
查看>>
通向财务自由之路03_判断之偏好:掌握市场为何对多数人来说如此之难
查看>>
通向财务自由之路04_设定你的目标
查看>>
通向财务自由之路05_选择一个有效的理念
查看>>
通向财务自由之路06_适应大环境的交易策略
查看>>
通向财务自由之路07_利用方案设法启动你的系统
查看>>
通向财务自由之路08_入市或市场时机选择
查看>>
通向财务自由之路09_知道何时收手:如何保护你的资本
查看>>