mysql的count(*)的优化,获取千万级数据表的总行数
一、前言
这个问题是今天朋友提出来的,关于查询一个1200w的数据表的总行数,用count(*)
的速度一直提不上去。找了很多优化方案,最后另辟蹊径,选择了用explain
来获取总行数。
二、关于count的优化
网上关于count()
优化的有很多。博主这边的思路就是没索引的就建立索引关系,然后使用count(1)
或者count(*)
来提升速度。这两个函数默认使用的是数据表中最短的那个索引字段。我朋友这边因为表中只有一个索引字段,所以使用count(1)
和count(*)
没什么区别。
MySQL中聚合函数count的使用和性能优化
mysql count(*) 会选哪个索引?
大家可以参考这两个博客,都挺不错的。
三、使用explain获取行数
1、关于explain
关于explain
,使用mysql
的都知道,这个函数是专门用于查看sql语句的执行效率的,网上可供参考的文章很多。
定义: explain 命令速度很快,因为 explain 用并不真正执行查询,而是查询优化器【估算】的行数。
我们使用explain
之后,会看到返回很多参数,其中:
rows:显示MySQL认为它执行查询时必须检查的行数。就是这个东西了,既然我们要获取的是数据表的行数,那么可以使用:
explain select * from table;
2、关于返回值
以前博主也没注意过返回值的问题,都是直接通过phpmyadmin
来查看sql
的执行效率。这次因为要用到rows
的值,所以就打印了一下,原来这个explain
函数是会返回一个数组。这样我们就能通过这个数组获取到我们需求的rows
。
这里直接获取这个值即可。速度极快。原来查询速度是2.33s,换成只用explain
之后,速度仅为0008s,提升十分巨大。
朋友博客:https://www.happyrmb.com/index/article/show/id/69.html
end
====================== 2019/3/7日补充 =============================
explain的rows结果算是一个大概的统计结果。而count统计的是比较准确的,如果要追求准确的条数,那就使用count查询最好,如果是要大概的结果,那可以使用explain的rows当做结果,正常来说,rows的数值会比count大一些,特别是加的有where条件的话,row的结果是大于Count的结果的。
例如:
举个网上的例子来说,假如有一个语句 select * from t where column_a = 1 and column_b = 2;
全表假设有100条记录,column_a
字段有索引(非联合索引),column_b
没有索引。
column_a = 1
的记录有20条, column_a = 1 and column_b = 2
的记录有5条。
那么最终查询结果应该显示5条记录。 explain结果中的rows应该是20. 因为这20条记录mysql引擎必须逐行检查是否满足where条件。
关于explain不准确:
关于explain不准确的问题,可以参考国外的一篇文章:
https://www.percona.com/blog/2006/07/24/mysql-explain-limits-and-errors/
需要注意不能完全相信explain的结果,特别是在使用limit的时候,结果也许会错的很离谱。其次,explain的结果也有可能会走错,一般发生在子查询的时候比较多。参考下面博客:
MySQL执行计划显示与执行过程不符合一例
这里多谢笑看泥鳅小同学的指正和讨论!
end
mysql的count(*)的优化,获取千万级数据表的总行数相关推荐
- mysql 亿级表count_码云社 | 砺锋科技-MySQL的count(*)的优化,获取千万级数据表的总行数 - 用代码改变世界...
专注于Java领域优质技术号,欢迎关注 作者:李长念 一.前言 这个问题是今天朋友提出来的,关于查询一个1200w的数据表的总行数,用count(*)的速度一直提不上去.找了很多优化方案,最后另辟蹊径 ...
- MySQL 的 count(*) 的优化,获取千万级数据表的总行数
一.前言 这个问题是今天朋友提出来的,关于查询一个1200w的数据表的总行数,用count(*)的速度一直提不上去.找了很多优化方案,最后另辟蹊径,选择了用explain来获取总行数. 二.关于cou ...
- mysql 查询表总行数字段_MySQL的count(*)的优化,获取千万级数据表的总行数
这个问题是今天朋友提出来的,关于查询一个1200w的数据表的总行数,用count(*)的速度一直提不上去.找了很多优化方案,最后另辟蹊径,选择了用explain来获取总行数. 网上关于count()优 ...
- mysql count 百万级_MySQL 的 count(*) 的优化,获取千万级数据表的总行数
一.前言 二.关于count的优化 三.使用explain获取行数1.关于explain 2.关于返回值 一.前言 这个问题是今天朋友提出来的,关于查询一个1200w的数据表的总行数,用count(* ...
- server sql 数据总行数_SqlServer中获取数据库中每个表的行数
CREATE TABLE #RowCounts(NumberOfRows BIGINT,TableName VARCHAR(128)) EXEC sp_MSForEachTable 'INSERT I ...
- 给第一行单元格赋值WPS JS获取工作表的总行数WPS JS获取工作表的总行数
戳我,了解更多相关办公的小技巧 给第一行单元格赋值 1.在计算机中有一种ASCII编码,其中A在计算机中的表示的数字是65,a的ascii码是97,b的ascii码是98. 2.从A1到F1可以看到第 ...
- 给第一行单元格赋值 + WPS JS获取工作表的总行数 + WPS JS获取工作表的总行数
戳我,了解更多相关办公的小技巧 给第一行单元格赋值 1.在计算机中有一种ASCII编码,其中A在计算机中的表示的数字是65,a的ascii码是97,b的ascii码是98. 2.从A1到F1可以看到第 ...
- mysql 1千万 like优化_MYSQL千万级数据量的优化方法积累
1.分库分表 很明显,一个主表(也就是很重要的表,例如用户表)无限制的增长势必严重影响性能,分库与分表是一个很不错的解决途径,也就是性能优化途径,现在的案例是我们有一个1000多万条记录的用户表mem ...
- 物理机存放mysql实例原则_MySQL优化笔记(四)--表的设计与优化(单表、多表)...
前面讲了SQL优化以及索引的使用.设计优化了,那么接下来就到表的设计与优化啦!!!真实地去设计优化单表结构以及讲述多表设计基本原则(结合真实的生产环境的取舍来讲述). 文章结构:(1)单表设计与优化: ...
最新文章
- 还在封装各种 Util 工具类?这个神级框架帮你解决所有问题!
- 程序员求职面试三部曲之一:选择合适的工作单位
- GD32 使用stm32 固件库
- 解析统计文本文件中的字符数、单词数、行数。
- php数组函数序列之array_unshift() 在数组开头插入一个或多个元素
- 搭建完全分布式的hadoop[转]
- VScode配置C/C++环境以及stdafx.h报错解决方法
- 海康威视录像机(DVR)卡在开机画面
- 敏捷开发工具scrum
- zcmu-1359 NBA (水题)
- 世界七大数学难题——千年大奖问题(转载)
- 使用jQuery实现五星好评
- MiCO系统开发MiCoder-IDE安装遇到的坑
- mysql 如何看索引命中_mysql索引命中规则讲解
- oracle增加表空间文件
- 支付宝年账单html5,2018支付宝年账单哪里查?支付宝2018年度账单怎么看
- it之家鸿蒙手机系统,IT之家安卓版新功能!支持识别鸿蒙系统与鸿蒙应用,无需更新...
- 机器人开发--伺服电机介绍
- docker仓库harbor安装与使用
- windows软件安全策略目录及类型
热门文章
- xp mysql字符集与乱码_解决MYSQL中文乱码问题三种方法
- Can‘t connect to HTTPS URL because the SSL module is not available
- c++ opencv 基本操作
- android GLES20 color
- Caffe学习系列(8):solver优化方法
- FIFOQueue '_4_batch_processing/batch_join/fifo_queue' is closed and has insu
- Python绘图 二维、三维
- h5首页加载慢_H5网站好不好?
- 计算机算法的发展动态,计算机算法动态规划讲解.ppt
- c++语言程序设计案...,C++程序设计案.ppt