sql语句中count(*),count(1),count(id)区别详解
来源:互联网 发布:杭州seo 编辑:程序博客网 时间:2024/06/06 05:34
1.前言
相信大多数有一定经验的phper都碰到过这个问题,count(*)和count(1),以及count('id')列有什么区别呢,这三者到底有什么不同呢,今天我将为此做深层的剖析,各位猿友们,注意看哈。。。。。
2.问题详解
count(*)和count(1)其实并没有区别,这两者都会将表中所有行都算进来,也就是该表的总行数
实例如下:
两者的结果相同并没有区别,这时因为count()中的值均不是null,只要不是null,就会选取所有的行,而当用count(null)查询时结果为0,如下:
原因是当count()括号内的值为null时,mysql内部自动返回0,不进行进一步查询。
以上是非null且不是表中的列名的情况,下面说说count(id)和count(1),以及count(*)这两者的区别。
具体区别我们通过一个实例可以看得更清晰:t是一个表,id为表中的唯一列,t表中有三条数据如下:
下面看一下count(id)和count(1),以及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的行数
- sql语句中count(*),count(1),count(id)区别详解
- sql语句中count(*),count(1),count(id)区别详解
- SQL语句中count(1)和count(*)的区别
- SQL语句中count(1)和count(*)的区别
- sql server中count(*),count(col),count(1)的区别
- SQL语句中count(1)count(*)count(字段)用法的区别
- sql count(*) count(1)count(colnum)区别
- sql中count(0),count(1),count(),count(列名)
- SQL里的count(*)、count(1)、count(column_name)的区别
- sql语句中count(*)与count(1)以及count(字段名)的异同点
- SQL Server中count(*), count(col), count(1)的对比
- SQL Server中count(*), count(col), count(1)的对比
- SQL Server中count(*), count(col), count(1)的对比
- count(*),count(1),count(id),count(rowid)的效率
- count(*),count(1),count(col)的区别
- count(*) count(1) count(column)的区别
- count(*),count(1)和count(field)区别
- count(*)、count(1)、count(column)的区别
- 优秀工程师-NSNotificationCenter
- Spring+SpringMVC+Hibernate框架完整版配置(基于xml)
- PHP引号区别
- HttpHandler一般处理程序的简单使用
- STL六大组件
- sql语句中count(*),count(1),count(id)区别详解
- Quicker.em 的函数内容
- 最完美ThinkPHP Nginx 配置文件
- 编程找出1000以内的完数,并按下面格式输出因子:6 its factors are 1 2 3
- Web页面的数据导出excel时的格式问题
- SpringBoot Thymeleaf web实例
- 如何优雅的停止服务(ShutdownHook)
- Linux(Centos)之安装Nginx及注意事项
- eclipse构建maven项目整合SSM(spring+springMVC+mybatis)框架