Which one is faster count(*) or count(1) ?

Showing Answers 1 - 5 of 5 Answers

Pat

  • Aug 14th, 2006
 

I've always believed count(1) was faster as it doesn't have to return all columns, just the row identity. But logically speaking the optimiser should take care of that so they should translate into the same underlying code

Rashmi121

  • May 9th, 2008
 

count (1) is faster than count(*) because count(*) returns all the rows as given in the select stmt including duplicate and null values while count(1)  or count(expr) will return all non-null values in column 1.

  Was this answer useful?  Yes

chrisjej

  • Jun 23rd, 2010
 

select count(*) does not need to fetch all column data - which you can see whenever the showplan chooses to perform the query using an index.

I doubt there is a difference - and when I just tried to benchmark this, the CPU time and logical reads were identical.

The following will usually (but not always) return the correct count of a table:
    select sum(ROWCNT(i.doampg))
    from sysindexes i,
     sysobjects u
    where i.id =  u.id
    and u.type = "U"
    and u.name = "$table_name"

and is extremely fast.

  Was this answer useful?  Yes

Give your answer:

If you think the above answer is not correct, Please select a reason and add your answer below.

 

Related Answered Questions

 

Related Open Questions