troubleshooting Question

SQL Case Statements Evaluation

Avatar of Bobby X
Bobby XFlag for United States of America asked on
SQL* T-SQLMicrosoft SQL Server
1 Comment1 Solution21 ViewsLast Modified:

Could someone please tell me what's wrong with these case statements (see below). Please see my comments below in the 'where' clause:

select c.Id, c.first_name, c.last_name,,
from customers c
where c.type = 2
and (
        when ((c.first_name like 'John%' and c.last_name like '%Christian%') or c.last_name like '%John Christian%')
            THEN 1 -- If this returns 1, I want the rest of the 'else' block below to skip, how do I do that?
        else -- This 'else' block for some reason is always running even though tht above 'THEN' returns 1
                when (c.first_name like 'John%' or c.last_name like '%Christian%')
                    then 1
                    else 0
    end = 1

Many thanks in advance.
Log in to continue reading
Become an EE member today7-DAY FREE TRIAL
Members can start a 7-Day Free trial then enjoy unlimited access to the platform for $9.99/mo
View membership options
Unlock 1 Answer and 1 Comment.
Learn why we charge membership fees
We get it - no one likes a content blocker. Take one extra minute and find out why we block content.
See how we're fighting big data
The Value of Experts Exchange in My Daily IT Life

Experts Exchange (EE) has become my company's go-to resource to get answers. I've used EE to make decisions, solve problems and even save customers. OutagesIO has been a challenging project and... Keep reading >>


Owner of Outages.IO
Phoenix, Arizona, United States
Member Since 2016
Join a full scale community that combines the best parts of other tools into one platform.
Unlock 1 Answer and 1 Comment.
View membership options
“All of life is about relationships, and EE has made a virtual community a real community. It lifts everyone's boat.”
William Peck

Member since 2004