Oracle中count(*)和count(1)有什么区别?

2024-11-11 20:25:47
推荐回答(4个)
回答(1):

count(1)与count(*)比较:
如果你的数据表没有主键,那么count(1)比count(*)快
如果有主键的话,那主键(联合主键)作为count的条件也比count(*)要快
如果你的表只有一个字段的话那count(*)就是最快的啦
count(*) count(1) 两者比较。主要还是要count(1)所相对应的数据字段。
如果count(1)是聚索引,id,那肯定是count(1)快。但是差的很小的。
因为count(*),自动会优化指定到那一个字段。所以没必要去count(?),用count(*),sql会帮你完成优化的

回答(2):

没有区别
查询结果一样,运行速度也基本没差

回答(3):

*号代表,统计所有字段个数,1是只统计单个字段个数

回答(4):

  count(*)运算中,所有行都要参与运算
  count(1)中,只有非空值参与运算,而且这个效率高些