We help IT Professionals succeed at work.

find null and all the null column in one select query

100 Views
Last Modified: 2018-10-16
Hi ,
I have a table table A having column col1,col2,col3,col4

I want to select the data in the table which has null values but with a statement which shows that what are the column having null values as below example:

INPUT:

col1 col2 col3
A               B
         X      B
A              

OUTPUT:

col1 col2 col3  statement
A               B      NULL IS COL2
         X               NULL IS COL1,COL3
A                        NULL IS COL2,COL3
Comment
Watch Question

nociSoftware Engineer
CERTIFIED EXPERT
Distinguished Expert 2019

Commented:
So you have to write out some queries....
(for 3 binary options: 8 queries:  2 ^ 3)

select * from A where NOT col1 IS NULL  and NOT col2  IS NULL and NOT col3  IS NULL;
select * from A where          col1 IS NULL  and NOT col2 IS NULL and NOT col3 IS NULL ;
select * from A where NOT col1 IS NULL  and          col2  IS NULL and NOT col3  IS NULL;
select * from A where          col1 IS NULL  and          col2 IS NULL and NOT col3 IS NULL ;
select * from A where NOT col1 IS NULL  and NOT col2  IS NULL and         col3  IS NULL;
select * from A where          col1 IS NULL  and NOT col2 IS NULL and          col3 IS NULL ;
select * from A where NOT col1 IS NULL  and          col2  IS NULL and        col3  IS NULL;
select * from A where          col1 IS NULL  and          col2 IS NULL and         col3 IS NULL ;

each of these queries will show their specific values.
Scott PletcherSenior DBA
CERTIFIED EXPERT
Most Valuable Expert 2018
Distinguished Expert 2019

Commented:
SELECT *,
      STUFF('NULL IS' +
            CASE WHEN col1 IS NULL THEN ',COL1' ELSE '' END +
            CASE WHEN col2 IS NULL THEN ',COL2' ELSE '' END +
            CASE WHEN col3 IS NULL THEN ',COL3' ELSE '' END, 8, 1, ' ') AS statement
FROM /*replace (...) with your table name*/ (
    VALUES('A', NULL, 'B'),
              (NULL, 'X', NULL),
              ('A', NULL, NULL),
              ('SHOULD', 'NOT', 'SELECT')
) AS test_data(col1, col2, col3)
WHERE col1 IS NULL OR col2 IS NULL OR col3 IS NULL
CERTIFIED EXPERT
Most Valuable Expert 2012
Distinguished Expert 2019
Commented:
This one is on us!
(Get your first solution completely free - no credit card required)
UNLOCK SOLUTION

Gain unlimited access to on-demand training courses with an Experts Exchange subscription.

Get Access
Why Experts Exchange?

Experts Exchange always has the answer, or at the least points me in the correct direction! It is like having another employee that is extremely experienced.

Jim Murphy
Programmer at Smart IT Solutions

When asked, what has been your best career decision?

Deciding to stick with EE.

Mohamed Asif
Technical Department Head

Being involved with EE helped me to grow personally and professionally.

Carl Webster
CTP, Sr Infrastructure Consultant
Empower Your Career
Did You Know?

We've partnered with two important charities to provide clean water and computer science education to those who need it most. READ MORE

Ask ANY Question

Connect with Certified Experts to gain insight and support on specific technology challenges including:

  • Troubleshooting
  • Research
  • Professional Opinions
Unlock the solution to this question.
Join our community and discover your potential

Experts Exchange is the only place where you can interact directly with leading experts in the technology field. Become a member today and access the collective knowledge of thousands of technology experts.

*This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply.

OR

Please enter a first name

Please enter a last name

8+ characters (letters, numbers, and a symbol)

By clicking, you agree to the Terms of Use and Privacy Policy.