SQL聚合操作之-count(*)记录数

count(*) :记录数

count(*)和count(1)其实并没有区别,这两者都会将表中所有行都算进来,也就是该表的总行数.

实例如下:

1、使用 select * from emp;查询,执行sql语句,显示结果如下:

2、 使用select count(*) from emp;执行sql语句,显示结果如下:

3、 使用select count(1) from emp;执行sql语句,显示结果如下:

两者的结果相同并没有区别,这时因为count()中的值均不是null,只要不是null,就会选取所有的行,而当用count(null)查询时结果为0,如下:

4、使用select count(null) from emp;执行sql语句,显示结果如下:

原因:当count()括号内的值为null时,mysql内部自动返回0,不进行进一步查询。

以上是非null且不是表中的列名的情况,下面说说count(id)和count(1),以及count(*)这两者的区别

使用sql语句查询后:select count(ename) from emp; 结果如下:

  • count(列名)  本来的结果集如下

有结果可知:count(列名)时,如果该列的值为null时,改行不计入count总数中,这也就是count(列名)和count(1),count(*)等其他count(非列名和非null)的区别

3.总结

此处设定count(a),其中a为变量,可以为各种值,下面根据a的不同值,得出不同的count(a)的结果

1)当a = null时,count(a)的值为0;

2)当a != null 且不是表的列名的时候,count(a)为该表的行数;

3)当a是表的列名时,count(a)为该表中a列的值不等于null的行的总数,它和2)中的差值就是该表中a列值为null的行数

 


版权声明:本文为SmCai原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。