COUNT(1)和COUNT(*)区别

项目经常用到count(1),但是和count(*)什么区别?

从下面实验结果来看,Count (*)和Count(1)查询结果是一样的,都包括对NULL的统计,而count(列名) 是不包括NULL的统计。

图1:

图2:

PS:

如果表没有主键,count(1)比count(*)快.

如果有主键的话,主键作为count的条件时候count(主键)最快.

如果表只有一个字段的话那count(*)就是最快的.

如果使用count(*)多的话,建议使用指定列建立索引。

时间: 2024-08-10 15:09:26

COUNT(1)和COUNT(*)区别的相关文章

select count(*)和select count(1)的区别 (转)

A 一般情况下,Select Count (*)和Select Count(1)两着返回结果是一样的 假如表沒有主键(Primary key), 那么count(1)比count(*)快, 如果有主键的話,那主键作为count的条件时候count(主键)最快 如果你的表只有一个字段的话那count(*)就是最快的 count(*) 跟 count(1) 的结果一样,都包括对NULL的统计,而count(column) 是不包括NULL的统计 1.select 1 与 select *的区别 se

关于数据库优化1——关于count(1),count(*),和count(列名)的区别,和关于表中字段顺序的问题

1.关于count(1),count(*),和count(列名)的区别 相信大家总是在工作中,或者是学习中对于count()的到底怎么用更快.一直有很大的疑问,有的人说count(*)更快,也有的人说count(列名)更快,那到底是谁更快,我将会在本文中详细介绍一下到底是count(1),count(*)和count(列明)的区别,和更适合的使用场景. 往常在工作中有人会说count(1)比count(*)会快,或者相反,首先这个结论肯定是错的,实际上count(1)和count(*)并没有区别

select count(*)和select count(1)的区别

一般情况下,Select Count (*)和Select Count(1)两着返回结果是一样的 假如表沒有主键(Primary key), 那么count(1)比count(*)快, 如果有主键的話,那主键作为count的条件时候count(主键)最快 如果你的表只有一个字段的话那count(*)就是最快的 count(*) 跟 count(1) 的结果一样,都包括对NULL的统计,而count(column) 是不包括NULL的统计 1.select 1 与 select *的区别 sele

SQL语句中count(1)count(*)count(字段)用法的区别

SQL语句中count(1)count(*)count(字段)用法的区别 在SQL语句中count函数是最常用的函数之一,count函数是用来统计表中记录数的一个函数, 一. count(1)和count(*)的区别 1. count(1)和count(*)的作用: 都是检索表中所有记录行的数目,不论其是否包含null值. 2. 区别:但是count(1)比count(*)效率更高 二 . count(字段)与count(1)和count(*)的区别 count(字段)的作用是检索表中的这个字段

count(*),count(1)和count(主键) 区别

看如下数据: 1 SQL> select count(*) from ysgl_compile_reqsub; 2 3 COUNT(*) 4 ---------- 5 5288265 6 7 已用时间: 00: 00: 07.51 8 SQL> select count(1) from ysgl_compile_reqsub; 9 10 COUNT(1) 11 ---------- 12 5288265 13 14 已用时间: 00: 00: 00.68 15 SQL> select c

Oracle基础之count(1)和count(*)的区别

在数据库中Count(*)或者Count(1)或者Count([列])或许是最常用的聚合函数.很多人其实对这三者之间是区分不清的.本文会阐述这三者的作用,关系以及背后的原理. 我在网上看到一些所谓的优化说建议不使用Count(* )而是使用Count(1),从而可以提升性能,给出的理由是Count( *)会带来全表扫描.而实际上如何写Count并没有区别. Count(1)和Count(*)实际上的意思是,评估Count(XXX)中的表达式XXX是否为NULL,如果为NULL则不计数,而非NUL

论证-select count(*)和select count(1)的区别

前言:今天看到同事转载的一篇<select count(*)和select count(1)的区别>的博文,兴致所致,就像对文中提出的结论进行验证一下: 从内容来看,主要是有主键和没有主键的影响,那么 第一步:创建test1(有主键),test2(无主键)两张表 CREATE TABLE `test1` ( `id` int(12) NOT NULL AUTO_INCREMENT, `value` int(12) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=In

select count(*)和select count(1)的区别和效率差异

一般情况下,Select Count (*)和Select Count(1)两着返回结果是一样的 假如表沒有主键(Primary key), 那么count(1)比count(*)快, 如果有主键的話,那主键作为count的条件时候count(主键)最快 如果你的表只有一个字段的话那count(*)就是最快的 count(*) 跟 count(1) 的结果一样,都包括对NULL的统计,而count(column) 是不包括NULL的统计 1.select 1 与 select *的区别 sele

count(*),count(1)和count(字段)的区别

count(*),count(1)和count(字段)的区别 之前在写sql语句时,常常使用count(*)来执行查询数据条数,也使用过count(字段)来针对某一特殊字段进行查询,今天接触到了count(1)也可以用来进行数据统计,下来查看资料,对它们有了一定的了解. 很多人认为count(1)执行的效率会比count(*)高,原因是count(*)会存在全表扫描,而count(1)可以针对一个字段进行查询.其实不然,count(1)和count(*)都会对全表进行扫描,统计所有记录的条数,包