Go Premium for a chance to win a PS4. Enter to Win

x
?
Solved

Complex conditional WHERE statement with CASE

Posted on 2008-09-29
5
Medium Priority
?
211 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 74

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 74

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 74

Accepted Solution

by:
sdstuber earned 750 total points
ID: 22597144
or

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

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

Concerto's Cloud Advisory Services

Want to avoid the missteps to gaining all the benefits of the cloud? Learn more about the different assessment options from our Cloud Advisory team.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

'Between' is such a common word we rarely think about it but in SQL it has a very specific definition we should be aware of. While most database vendors will have their own unique phrases to describe it (see references at end) the concept in common …
Occasionally there is a need to clean table columns, especially if you have inherited legacy data. There are obviously many ways to accomplish that, including elaborate UPDATE queries with anywhere from one to numerous REPLACE functions (even within…
Please read the paragraph below before following the instructions in the video — there are important caveats in the paragraph that I did not mention in the video. If your PaperPort 12 or PaperPort 14 is failing to start, or crashing, or hanging, …
Despite its rising prevalence in the business world, "the cloud" is still misunderstood. Some companies still believe common misconceptions about lack of security in cloud solutions and many misuses of cloud storage options still occur every day. …
Suggested Courses

782 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