ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [MSSQL] CASE 문 . 조건에 따라 값 정하기 ! CASE WHEN THEN
    IT /DataBase 2013. 6. 20. 09:42
    728x90

    조건에 따라서 값을 지정해 주는 CASE문에 대해서 알아보겠습니다~ 

     

    CASE 문의 형식은  

     

    CASE 컬럼  

    WHEN 조건1 THEN 값1 

    WHEN 조건2 THEN 값2 

    ELSE 값3 

    END 

    입니다. 

     

    컬럼이 조건1 일때는 값1 을 조건2일때는 값2를 반환하고 조건에 맞지 않는 경우에는 값3 을 반환하는것입니다. 

     

     

    CASE 문을 사용하는 경우는 

     

    첫 번째는 약어나 코드를 읽기 쉬운 값으로 바꿔 줄 때 사용합니다. 

    두 번째는 데이터를 범주화 하는것입니다 

     

    예를 들면

     학생들 성적을 

    90~100 은 A 

    80~90 은 B 

    아니면 C 

     

    A라고 등록된 걸 장학생 

    D 라고 등록된 걸 똑똑하지만 안하는 친구 

    아니면 좋은친구


    간단하죠 하하하 

     

     

    도움말에 있는 첫번째 사용예제를 봅시다. 

     

    USE AdventureWorks2008R2;  

    GO  

    SELECT ProductNumber, Category =  

    CASE ProductLine  

    WHEN 'R' THEN 'Road'  

    WHEN 'M' THEN 'Mountain'  

    WHEN 'T' THEN 'Touring'  

    WHEN 'S' THEN 'Other sale items' 

    ELSE 'Not for sale'  

    END, Name  

    FROM Production.Product  

    ORDER BY ProductNumber; GO  

     

    이 쿼리는  A학생을 장학생이라고 바꿔주는거랑 비슷합니다.

    R 이면 Road 로 M 이면 Mountain 으로 바꿔주는거 아시겠죠?

    마지막엔 ORDER BY 문을 사용해서 ProductNumber 을 기준으로 오름차순 정렬 합니다. 

    ORDER BY 문의 기본값은 오름차순인 ASC 입니다. 

     

    도움말에 있는 두번째 예제 입니다. 

    보면 값의 범위를 지정하는것처럼 보이죠 하하..

    이번엔 성적에 따라 A, B, C 로 나눠 주는거랑 비슷합니다. 

     

    USE AdventureWorks2008R2;  

    GO  

    SELECT ProductNumber, Name, 'Price Range' =  

    CASE  

    WHEN ListPrice = 0 THEN 'Mfg item - not for resale'  

    WHEN ListPrice < 50 THEN 'Under $50'  

    WHEN ListPrice >= 50 and ListPrice < 250 THEN 'Under $250'  

    WHEN ListPrice >= 250 and ListPrice < 1000 THEN 'Under $1000'  

    ELSE 'Over $1000' 

    END  

    FROM Production.Product ORDER BY ProductNumber ; GO  

     

    50보다 작은건 모두 under $50 으로 

    50보다 크거나 같고 250 보다 작은건 under $ 250 으로 묶어 주는 역할을 하게 됩니다. 

    마찬가지 마지막에 ORDER BY 문 ProductNumber 열을 기준으로 오름차순 정렬을 하게 됩니다.


    도움말의 예제를 보니까 못보던게 있습니다. 

     

    GO 를 언제 쓰는가 

     나타나는 위치를 보면 문장의 끝에 위치 하고 있습니다. 

    맞았어요~~  

     GO 는 그 문장의 끝을 말하는 역할을 합니다. 


    이것도 끝!

    GO 


    도움말을 생활화 합시다. 블로그 보다 퀄리티 GOOD


Designed by Tistory.