select count(*), select count(0), select count(1) from table

在统计表的行数时候,经常用到 select count(*)

然而对于行数很多的大表,这样的查询速度将会很慢。因为这样的查询对表的每一行都会进行每个列的扫描。

比较快的办法是 select count(0), 这样每一行就只是扫描行头信息。

以上2种都是进行的全表扫描。

更快的是 select count(唯一索引列) 这样的查询会走索引。

 

WITH t

     AS (SELECT NULL a, NULL b FROM DUAL

         UNION ALL

         SELECT 1, NULL FROM DUAL

         UNION ALL

         SELECT NULL, 1 FROM DUAL)

SELECT COUNT (*)

     , COUNT (0)

     , COUNT (1)

     , COUNT (a)

     , COUNT (b)

  FROM t;

Oracle > count(*) / count(0) / count(1) | order by 1, 2_代码

 

 

WITH t

     AS (SELECT NULL a, NULL b FROM DUAL

         UNION ALL

         SELECT 1, NULL FROM DUAL

         UNION ALL

         SELECT 2, 2 FROM DUAL

         UNION ALL

         SELECT NULL, 1 FROM DUAL)

         select a, b

         from t

         order by 2; --整个表中的第2

Oracle > count(*) / count(0) / count(1) | order by 1, 2_代码_02