当前位置:   article > 正文

select * 与 count(*)数量不一致_技术分享 | MySQL:count(*)、count(字段) 实现上区别

count 和 select 的条数不一样
作者: 高鹏 文章末尾有他著作的《深入理解 MySQL 主从原理 32 讲》,深入透彻理解 MySQL 主从,GTID 相关技术知识。

继上一篇文章:

MySQL:查询字段数量多少对查询效率的影响 ?

我们继续来讨论一下 count(*)、count(字段)实现上的区别。注意我们这里都使用 Innodb 做为存储引擎,不讨论其他引擎。因为了有了前面的讨论,更容易看出它们的区别,这里我们有如下注意点:

  • 我们需要做到执行计划一样,这里以全表扫描为例。实际上 count 很可能使用到覆盖索引(Using index),本文主要讨论它们实现的异同。

  • count(*) 和 count(字段) 在结果上可能并不一致。比如 count(字段),但是某些行本字段为 NULL 的话那么将不会统计行数,下面将会说明这种 NULL 判断的位置。本文还是使用简单的全表扫描来进行对比实现上的区别。首先我们要明确的是 count 使用的是一个 COUNT 计数器。

一、使用示例 在示例中我们也可以看到两个语句的结果实际上并不一致。

mysql> show create table baguai_f \G

*************************** 1. row ***************************

Table: baguai_f

Create Table: CREATE TABLE `baguai_f` (

`id` int(11) DEFAULT NULL,

`a` varchar(20) DEFAULT NULL,

`b` varchar(20) DEFAULT NULL,

`c` varchar(20) DEFAULT NULL

) ENGINE=InnoDB DEFAULT CHARSET=utf8

1 row in set (0.00 sec)

mysql> select * from baguai_f ;

+------+------+------+------+

| id | a | b | c |

+------+------+------+------+

| 1 | g | g | NULL |

| 1 | g1 | g1 | g1 |

| 3 | g2 | g2 | g2 |

| 4 | g | g | NULL |

| 5 | g | g | NULL |

| 6 | g3 | g3 | g3 |

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号