字段)区别"/>
count(*) 和 count(1)和count(字段)区别
- 执行效果上看:
- count(*) 包括了所有的列,相当于行数,在统计结果的时候,不会忽略字段值为NULL的列 ;
- count(1) 包括了忽略所有列,用1代表代码行,在统计结果的时候,不会忽略字段值为NULL的列 ;
- count(列名) 只包括列名那一列,在统计结果的时候,会忽略字段值为值为NULL的列(这里的空不是指 空字符串“” 或者 0,而是表示null)的计数,即某个字段值为NULL时,不统计。
- 执行效率上看:
- 列名为主键,count(列名)会比count(1)快 且 select count(主键)的执行效率是最优的;
- 列名不为主键,count(1)会比count(列名)快 ;
- 如果表多个列并且没有主键,则 count(1) 的执行效率优于 count(*) ;
- 如果表只有一个字段,则 select count(*)最优。
更多推荐
count(*) 和 count(1)和count(字段)区别
发布评论