Oracle: Finding Columns with only null values

前端 未结 8 2080
温柔的废话
温柔的废话 2021-01-17 21:11

I have a table with a lot of columns and a type column.

Some columns seem to be always empty for a specific type.

I want to create a view for each type and o

相关标签:
8条回答
  • 2021-01-17 21:52
    SELECT  t.column_name
    FROM    user_tab_columns t
    WHERE   t.nullable = 'Y'
            AND t.table_name = 'YOUR_TABLE_NAME'
            AND t.num_distinct = 0
    
    0 讨论(0)
  • 2021-01-17 21:52
    select
      count(col_1),
      count(col_2),
      count(col_3)
    from
      <table>
    

    returns how many records per column have a non-null value (at least in Oracle, that is.)

    For example

    drop table tq84_count_nulls;
    
    create table tq84_count_nulls (
      col_1  varchar(50),
      col_2  number,
      col_3  date
    );
    
    insert into tq84_count_nulls values (null, null, null);
    insert into tq84_count_nulls values ('xx', null, null);
    insert into tq84_count_nulls values (null,   42, null);
    insert into tq84_count_nulls values ('yy',   12, null);
    
    select
      count(col_1),
      count(col_2),
      count(col_3)
    from
      tq84_count_nulls;
    

    returns

    COUNT(COL_1) COUNT(COL_2) COUNT(COL_3)
    ------------ ------------ ------------
               2            2            0
    

    indicating that col_3 consists of nulls only.

    This idea can then be used to create the desired view.

    The table now needs also the *group_id*:

    drop table tq84_count_nulls;
    create table tq84_count_nulls (
      col_1    varchar(50),
      col_2    number,
      col_3    date,
      group_id varchar(2)
    );
    
    insert into tq84_count_nulls values (null, null, null, 'a');
    insert into tq84_count_nulls values ('xx', null, null, 'a');
    insert into tq84_count_nulls values (null,   42, null, 'a');
    insert into tq84_count_nulls values ('yy',   12, null, 'a');
    
    insert into tq84_count_nulls values (null, null, null, 'b');
    insert into tq84_count_nulls values (null, null, null, 'b');
    insert into tq84_count_nulls values (null,   42, null, 'b');
    insert into tq84_count_nulls values (null,   12, null, 'b');
    
    
    
    
    create or replace view nulls_per_type as 
    with n as (
      select
        count(col_1) col_1_count,
        count(col_2) col_2_count,
        count(col_3) col_3_count,
        group_id
      from
        tq84_count_nulls
      group by 
        group_id
    ),
    o as (
    select case col_1_count when 0 then 'COL_1 is always 0 for ' || group_id else null end u from n union all
    select case col_2_count when 0 then 'COL_2 is always 0 for ' || group_id else null end u from n union all
    select case col_3_count when 0 then 'COL_3 is always 0 for ' || group_id else null end u from n
    )
    select * from o where u is not null;
    

    Which, when selected returns:

    select * from nulls_per_type;
    
    COL_1 is always 0 for b
    COL_3 is always 0 for a
    COL_3 is always 0 for b
    
    0 讨论(0)
提交回复
热议问题