ShovelingLife
A Game Programmer
ShovelingLife
전체 방문자
오늘
어제
  • 분류 전체보기 (1076) N
    • 그래픽스 (57)
      • 공통 (19)
      • 수학 물리 (22)
      • OpenGL & Vulkan (1)
      • DirectX (14)
    • 게임엔진 (184) N
      • Unreal (69)
      • Unity (104) N
      • Cocos2D-X (3)
      • 개인 플젝 (8)
    • 코딩테스트 (221)
      • 공통 (7)
      • 프로그래머스 (22)
      • 백준 (162)
      • LeetCode (19)
      • HackerRank (2)
      • 코딩테스트 알고리즘 (8)
    • CS (235)
      • 공통 (21)
      • 네트워크 (44)
      • OS & 하드웨어 (55)
      • 자료구조 & 알고리즘 (98)
      • 디자인패턴 (6)
      • UML (4)
      • 데이터베이스 (7)
    • 프로그래밍 언어 (350) N
      • C++ (168)
      • C# (90)
      • Java (9)
      • Python (34) N
      • SQL (30)
      • JavaScript (8)
      • React (7)
    • 그 외 (10)
      • Math (5)
      • 일상 (5)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

  • Source Code 좌측 상단에 복사 버튼 추가 완료
  • 언리얼 엔진 C++ 빌드시간 단축 꿀팁
  • 게임 업계 코딩테스트 관련
  • 1인칭 시점으로 써내려가는 글들

인기 글

태그

  • 백준
  • 파이썬
  • Unity
  • 알고리즘
  • 배열
  • 그래픽스
  • 문자열
  • 유니티
  • 프로그래머스
  • 언리얼
  • C
  • 티스토리챌린지
  • 클래스
  • 포인터
  • C++
  • SQL
  • 오블완
  • c#
  • string
  • 함수

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
ShovelingLife

A Game Programmer

[SQL] CASE WHEN 표현식 사용법 (DECODE, IF)
프로그래밍 언어/SQL

[SQL] CASE WHEN 표현식 사용법 (DECODE, IF)

2024. 8. 21. 20:38

 

기본 사용법

if문 방식

비교 연산자 (>,<,=,<>), NULL 연산자 (IS NULL, IS NOT NULL)을 사용하여 조건을 부여할 수 있으며, 논리 연산자 (AND, OR)를 사용하여 여러 개의조건을 부여할 수 있다.

ELSE 부분은 생략이 가능하며 생략할 경우 조건에 맞지 않으면 NULL을 반환한다.

SELECT employee_id
     , first_name
     , job_id
     , CASE WHEN job_id = 13 THEN 'CLERK'
            WHEN job_id = 14 THEN 'MANAGER'
            ELSE 'N/A'
       END AS [job_title]
  FROM employees
 WHERe department_id IN (1, 3)

 

switch문 방식

SELECT employee_id
     , first_name
     , CASE job_id
            WHEN 13 THEN 'CLERK'
            WHEN 14 THEN 'MANAGER'
            ELSE 'N/A'
       END AS [job_title]
  FROM employees
 WHERE department_id = 3

고급 사용법

조건을 여러 개 부여하는 방법

논리 연산자 (AND, OR)를 사용하여 여러 개의 조건을 조합해서 사용할 수 있다.

SELECT employee_id
     , first_name
     , job_id
     , CASE WHEN department_id = 3 AND job_id = 13 THEN 'CLERK'
            WHEN department_id = 3 AND job_id = 14 THEN 'MANAGER'
       END AS [job_title]
  FROM employees
 WHERE department_id IN (1, 3)

 

WHERE 절에 사용하는 방법

WHERE 절에도 CASE 표현식을 사용할 수 있다. 인덱스 컬럼에 CASE 표현식 사용하면 쿼리 문의 속도에 영향을 미치므로 주의해야 한다. 단순 필터링 용도로만 사용해야 한다.

SELECT employee_id
     , first_name
     , job_id
     , salary
  FROM employees
 WHERE department_id IN (1, 3)
   AND (CASE WHEN salary >= 4000 THEN 1
             WHEN salary >= 3000 THEN 2
             WHEN salary >= 2000 THEN 3
       END) = 1

 

CASE 표현식을 중첩으로 사용하는 방법

중첩해서 사용할 경우 쿼리 문의 가독성이 떨어질 수 있으므로 주의해서 사용해야한다

SELECT employee_id
     , first_name
     , department_id
     , salary
     , CASE department_id
            WHEN 1 THEN
                 CASE WHEN salary >= 4000 THEN '1등급'
                      WHEN salary >= 3000 THEN '2등급'
                      WHEN salary >= 2000 THEN '3등급'
                 END
            WHEN 3 THEN
                 CASE WHEN salary >= 4000 THEN '1등급'
                      WHEN salary >= 3000 THEN '2등급'
                      WHEN salary >= 2000 THEN '3등급'
                 END
       END AS [salary_grade] 
  FROM employees
 WHERE department_id IN (1, 3)

 

출처

저작자표시 (새창열림)

'프로그래밍 언어 > SQL' 카테고리의 다른 글

[SQL] UNION / UNION ALL / UNION DISTINCT  (1) 2024.10.15
[SQL] CASE WHEN 조건 여러개 (다중 조건, 다중 칼럼)  (0) 2024.08.21
[SQL] 별칭 (Alias) 활용하기  (0) 2024.08.15
[SQL] 피봇에 대해 알아보자 (PIVOT, UNPIVOT)  (0) 2024.08.12
MS SQL IDE (Server Management Studio) 설치 및 오류 해결  (0) 2024.08.12
    '프로그래밍 언어/SQL' 카테고리의 다른 글
    • [SQL] UNION / UNION ALL / UNION DISTINCT
    • [SQL] CASE WHEN 조건 여러개 (다중 조건, 다중 칼럼)
    • [SQL] 별칭 (Alias) 활용하기
    • [SQL] 피봇에 대해 알아보자 (PIVOT, UNPIVOT)
    ShovelingLife
    ShovelingLife
    Main skill stack => Unity C# / Unreal C++ Studying Front / BackEnd, Java Python

    티스토리툴바