Solved

Complex conditional WHERE statement with CASE

Posted on 2008-09-29
5
202 Views
Last Modified: 2012-05-05
The query I'm trying to build is almost complete. The query is something like this:

SELECT *
FROM table
WHERE condition1
  AND field3 IN (CASE field2='ABC' THEN 'textvalue1', 'textvalue2', 'textvalue3' ELSE field3 END)

In normal language: If field2 contains the value 'ABC', then I want field3 to match any of three string values. If field2 doesn't contain the value 'ABC', field3 can be anything.

The following works (but is of no use to me):

SELECT *
FROM table
WHERE condition1
  AND field3 IN (CASE field2='ABC' THEN 'textvalue1'' ELSE field3 END)
0
Comment
Question by:VSdB
  • 4
5 Comments
 
LVL 3

Expert Comment

by:R_Janssen
ID: 22597090
Try encapsulating?
(CASE field2='ABC' THEN ('textvalue1', 'textvalue2', 'textvalue3') ELSE field3 END)?
 
No management studio at hand so can't test if this works. CASE's in SQL are limited so there is a chance you'll have to write it out a bit more detailed. aka. More if's and multiple select statements based on the information at that particular step.
 
0
 
LVL 73

Expert Comment

by:sdstuber
ID: 22597119
SELECT *
FROM table
WHERE condition1
  AND (field3 = (CASE field2='ABC' THEN 'textvalue1' ELSE field3 END)
    or field3 = (CASE field2='ABC' THEN 'textvalue2' ELSE field3 END)
     or field3 = (CASE field2='ABC' THEN 'textvalue3' ELSE field3 END)
)
     

0
 
LVL 73

Expert Comment

by:sdstuber
ID: 22597127
or

SELECT *
FROM table
WHERE condition1
  AND field3 in ( (CASE field2='ABC' THEN 'textvalue1' ELSE field3 END),
                         (CASE field2='ABC' THEN 'textvalue2' ELSE field3 END),
                         (CASE field2='ABC' THEN 'textvalue3' ELSE field3 END)
                       )
     
0
 
LVL 73

Accepted Solution

by:
sdstuber earned 250 total points
ID: 22597144
or

SELECT *
FROM table
WHERE condition1
  AND (field2 != 'ABC'
     or (field2='ABC' and  field3 in ('textvalue1', 'textvalue2', 'textvalue3' ))
         )
     
0
 
LVL 73

Expert Comment

by:sdstuber
ID: 22597256
Why only a B?  What else did you need?  If the answer was insufficient, please ask for further clarifications rather than assign a penalty grade
0

Featured Post

Free Trending Threat Insights Every Day

Enhance your security with threat intelligence from the web. Get trending threat insights on hackers, exploits, and suspicious IP addresses delivered to your inbox with our free Cyber Daily.

Join & Write a Comment

Suggested Solutions

If you find yourself in this situation “I have used SELECT DISTINCT but I’m getting duplicates” then I'm sorry to say you are using the wrong SQL technique as it only does one thing which is: produces whole rows that are unique. If the results you a…
Confronted with some SQL you don't know can be a daunting task. It can be even more daunting if that SQL carries some of the old secret codes used in the Ye Olde query syntax, such as: (+)     as used in Oracle;     *=     =*    as used in Sybase …
Internet Business Fax to Email Made Easy - With eFax Corporate (http://www.enterprise.efax.com), you'll receive a dedicated online fax number, which is used the same way as a typical analog fax number. You'll receive secure faxes in your email, fr…
Get a first impression of how PRTG looks and learn how it works.   This video is a short introduction to PRTG, as an initial overview or as a quick start for new PRTG users.

760 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

22 Experts available now in Live!

Get 1:1 Help Now