Oracle:如何计算null和非null行

时间:2011-04-01 11:24:59

标签: oracle select null grouping

我有一个包含两列的表,可能是null(以及其他一些列)。我想计算有多少行,其中列a,b,两列都没有设置为null。

在一个查询中,Oracle可以实现这一点吗?或者我是否必须为每个创建一个查询?例如,不能使用group by或其他一些我可能不知道的东西?

7 个答案:

答案 0 :(得分:46)

COUNT(expr)将计算expr不为空的行数,因此您可以使用以下表达式计算空值的数量:

SELECT count(a) nb_a_not_null,
       count(b) nb_b_not_null,
       count(*) - count(a) nb_a_null,
       count(*) - count(b) nb_b_null,
       count(case when a is not null and b is not null then 1 end)nb_a_b_not_null
       count(case when a is null and b is null then 1 end) nb_a_and_b_null
  FROM my_table

答案 1 :(得分:8)

这样的事情:

SELECT sum(case 
               when a is null and b is null then 1
               else 0
           end) as both_null_count,
       sum(case
               when a is null and b is not null then 1
               else 0
           end) as only_a_is_null_count
FROM your_table

您可以将其扩展为null / not null的其他组合

答案 2 :(得分:3)

select sum(decode(a,null,0,1)) as "NotNullCount", sum(decode(a,null,1,0)) as "NullCount"
from myTable;

根据需要重复多个字段。

答案 3 :(得分:1)

SQL>CREATE TABLE SAMPLE_TAB (COL1 NUMBER NOT NULL, COL2 DATE DEFAULT SYSDATE, COL3 VARCHAR2(20));
SQL>INSERT INTO SAMPLE_TAB(COL1,COL2,COL3) VALUES(121,SYSDATE-2,'SAMPLE DATA');
SQL>INSERT INTO SAMPLE_TAB(COL1,COL2,COL3) VALUES(122,NULL,NULL); --ASSIGN NULL TO COL2
SQL>INSERT INTO SAMPLE_TAB(COL1,COL3) VALUES(123,'SAMPLE DATA RECORD 3');--COL2 DEFAULT VALUE ASSIGN AS SYSDDATE AS PER STRUCTURE.
SQL>COMMIT;
SQL> SELECT * FROM SAMPLE_TAB;

SQL> SELECT *
FROM USER_TAB_COLUMNS U
WHERE 1=1
AND TABLE_NAME='SAMPLE_TAB'
AND NUM_NULLS!=0;

SQL> ANALYZE TABLE SAMPLE_TAB COMPUTE STATISTICS;


SQL> SELECT *
FROM USER_TAB_COLUMNS U
WHERE 1=1
AND TABLE_NAME='SAMPLE_TAB'
AND NUM_NULLS!=0;

答案 4 :(得分:0)

一种方法是:

select count(*) from table group by nvl2(a, 0, 1), nvl2(b, 0, 1) having nvl2(a,0,1) = nvl2(b,0,1);

答案 5 :(得分:0)

这对于我计算得到oracle表中一组列上空白单元格的总计数非常有效:我添加了修剪以将空白空间计为空

SELECT (sum(case 
           when trim(a) is null Then 1
           else 0
       end)) +
   (sum(case
           when trim(b) is null 
           else 0
       end)) +
   (sum(case
           when trim(c) is null 
           else 0
       end)) as NullCount
FROM your_table

希望这有帮助

干杯。

答案 6 :(得分:0)

可以在Oracle中完成一行:

SELECT COUNT(NVL(potential_null_column, 0)) FROM table;

函数 NVL 检查第一个参数是否为null并将其视为第二个参数的值。