I have many columns in oracle database and some new are added with values. I like to find out which columns have values other than 0 or null. So I am looking for column names for which some sort of useful values exists at least in one row.
How do I do this?
Update: This sounds very close. How do I modify this to suit my needs?
select column_name, nullable, num_distinct, num_nulls
from all_tab_columns
where table_name = 'SOME_TABLE'
You can query all the columns using the dba_tab_cols view and then see if there are columns which have values other than 0 or null.
If you have synonyms in some schemas, you mighty find some of the tables are repeated. You’ll have to change the code to cater to that.
Also, the check “is not equal to zero” might not be valid for columns that are not integers and will give errors if columns are of date datatype. You’ll need to add the conditions for those cases. use the Data_type column in dba_tab_cols and add the condition as needed.