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

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

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

인기 글

태그

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

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
ShovelingLife

A Game Programmer

[SQL] CASE WHEN 조건 여러개 (다중 조건, 다중 칼럼)
프로그래밍 언어/SQL

[SQL] CASE WHEN 조건 여러개 (다중 조건, 다중 칼럼)

2024. 8. 21. 21:38

CASE WHEN 조건 여러개 부여 (다중 조건)

CASE 표현식에서 여러개의 조건을 부여하기 위해서는 WHEN ~ THEN 구문을 반복해서 사용하면 된다.

WHEN~THEN 구문을 처음부터 순차적으로 값을 비교하여 일치하는 조건이 있으면 THEN 이후 값을 반환 후 더 이상 값을 비교하지 않고 종료한다.. 일치하는 조건이 없을 경우 NULL을 반환한다.

SELECT ename
     , job
     , CASE WHEN job = 'ANALYST'  THEN 'CASE 1'
            WHEN job = 'MANAGER'  THEN 'CASE 2'
            WHEN job = 'SALESMAN' THEN 'CASE 3'
       END AS case_result
  FROM emp
 WHERE job IN ('ANALYST', 'MANAGER', 'SALESMAN')

 

CASE WHEN 여러개 칼럼 조건 부여 (다중 칼럼)

여러개의 칼럼을 비교하는 조건을 부여해야 할 경우 AND 연산자를 사용하여 조건을 부여하면 된다.

모든 칼럼의 AND 조건을 만족해야 해당 값을 반환한다.

SELECT ename
     , job
     , deptno
     , sal
     , CASE WHEN job = 'ANALYST'  AND deptno = 20 AND sal >= 3000 THEN 'CASE 1'
            WHEN job = 'MANAGER'  AND deptno = 10 AND sal >= 2000 THEN 'CASE 2'
            WHEN job = 'SALESMAN' AND deptno = 30 AND sal >= 1500 THEN 'CASE 3'
       END AS case_result
  FROM emp
 WHERE job IN ('ANALYST', 'MANAGER', 'SALESMAN')

 

OR 연산자를 사용하여 여러개의 칼럼 조건 부여

여러개의 칼럼을 OR 연산자로 조건을 부여할 수 있으며, OR 조건 중 하나만 만족해도 해당 값을 반환하고 WHEN~THEN 조건 탐색을 종료한다.

JONES(MANAGER)는 첫 번째 CASE 조건 deptno = 20 만족하기 때문에 "CASE 1"을 반환하였다.

SELECT ename
     , job
     , deptno
     , sal
     , CASE WHEN job = 'ANALYST'  OR deptno = 20 OR sal >= 3000 THEN 'CASE 1'
            WHEN job = 'MANAGER'  OR deptno = 10 OR sal >= 2000 THEN 'CASE 2'
            WHEN job = 'SALESMAN' OR deptno = 30 OR sal >= 1500 THEN 'CASE 3'
       END AS case_result
  FROM emp
 WHERE job IN ('ANALYST', 'MANAGER', 'SALESMAN')

 

[Oracle] CASE WHEN 조건 여러개 (다중 조건, 다중 칼럼) (tistory.com)

저작자표시 (새창열림)

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

[SQL] 보안, 권한 부여 grant, revoke, role  (0) 2024.10.15
[SQL] UNION / UNION ALL / UNION DISTINCT  (1) 2024.10.15
[SQL] CASE WHEN 표현식 사용법 (DECODE, IF)  (0) 2024.08.21
[SQL] 별칭 (Alias) 활용하기  (0) 2024.08.15
[SQL] 피봇에 대해 알아보자 (PIVOT, UNPIVOT)  (0) 2024.08.12
    '프로그래밍 언어/SQL' 카테고리의 다른 글
    • [SQL] 보안, 권한 부여 grant, revoke, role
    • [SQL] UNION / UNION ALL / UNION DISTINCT
    • [SQL] CASE WHEN 표현식 사용법 (DECODE, IF)
    • [SQL] 별칭 (Alias) 활용하기
    ShovelingLife
    ShovelingLife
    Main skill stack => Unity C# / Unreal C++ Studying Front / BackEnd, Java Python

    티스토리툴바