count(列名)、count(1)和count()有什么区别.md

进行统计操作时,count中的统计条件可以三种选择:

EXPLAIN SELECT COUNT(*) FROM user;
EXPLAIN SELECT COUNT(列名) FROM user;
EXPLAIN SELECTCOUNT(1)FROM user;

执行效果上:

  • count()包括了所有的列在统计时不会忽略列值为null的数据
  • count(1)用1表示代码行,在统计时不会忽略列值为null的数据
  • count(列名)在统计时,忽略列值为空的数据,就是说某个字段的值为null时不统计。

执行效率上:

  • InnoDB引擎: count (字段) < count(1) = count()
    olnnoDB通过遍历最小的可用二级索引来处理select count()语句,除索引或优化器提示指示优化器使用不同的索引。如果二级索引不存在,则通过扫描聚集索引来处理。
  • InnoDB已同样的方式处理count(1)和count()
    MyISAM引擎: count (字段) < count(1) <= count()。MySAM存储了数据的准确行数,使用 count()会直接读取该行数,只有当第一列定义为NOT NULL时,count (1),才会执行该操作,所以优先选择 count()·count(列名)会遍历整个表,但不同的是,它会先获取列,然后判断是否为空,然后累加,因此count(列名)性能不如前两者。

注意:count(),这是SQL92 定义的标准统计行数的语法跟数据库无关,与NULL也无关。而count(列名) 是统
计列值数量,不计NULL,相同列值算一个。

posted @ 2024-02-26 22:37  哩个啷个波  阅读(6)  评论(0编辑  收藏  举报