[PL/SQL] PL/SQL 제어문 : IF, CASE [특정 조건에 맞을 때 처리하는 조건문]

2022. 3. 31. 23:30·▣ SQL : Database/PL SQL💾
728x90


1. 조건문 : IF문

- ORACLE IF문의 특징
1) 조건 다음에는 THEN, 문장 맨 마지막에는 END IF를 명기한다.
2) 조건이 1개 이상이면 ELSE IF가 아닌 ELSIF를 사용한다.
/* 조건이 1개일 경우 */
IF 조건 THEN
	조건처리;
END IF;

/* 조건이 2개일 경우 */
IF 조건 THEN
	조건처리 1;
ELSE
	조건처리 2;
END IF;

- IF문 예제

DECLARE
    VN_NUM1 NUMBER := 1;
    VN_NUM2 NUMBER := 3;
BEGIN
    IF VN_NUM1 >= VN_NUM2 THEN
        DBMS_OUTPUT.PUT_LINE(VN_NUM1 || '이 큰수');
    ELSE
        DBMS_OUTPUT.PUT_LINE(VN_NUM2 || '이 큰수');
    END IF;
END;
/

 

IF문을 사용한 PL/SQL 구문


- 조건이 여러 개인 IF문

/* 조건이 N개일 경우 */
IF 조건 THEN
	조건처리 1;
ELSIF 조건 THEN
	조건처리 2;
	…
ELSE
	조건처리 N;
END IF;

- 조건이 여러 개인 IF문 예제

DECLARE
    VN_SALARY NUMBER := 0;
    VN_DEPARTMENT_ID NUMBER := 0;
BEGIN
    VN_DEPARTMENT_ID := ROUND(DBMS_RANDOM.VALUE(10, 120), -1);
    DBMS_OUTPUT.PUT_LINE(VN_DEPARTMENT_ID);
    
    SELECT SALARY
    INTO VN_SALARY
    FROM EMPLOYEES
    WHERE DEPARTMENT_ID = VN_DEPARTMENT_ID
    AND ROWNUM = 1;
    
    DBMS_OUTPUT.PUT_LINE(VN_SALARY);
    
    IF VN_SALARY BETWEEN 1 AND 3000
        THEN DBMS_OUTPUT.PUT_LINE('낮음');
    ELSIF VN_SALARY BETWEEN 3001 AND 6000
        THEN DBMS_OUTPUT.PUT_LINE('중간');
    ELSIF VN_SALARY BETWEEN 6001 AND 10000
        THEN DBMS_OUTPUT.PUT_LINE('높음');
    ELSE
        DBMS_OUTPUT.PUT_LINE('최상위');
    END IF;
END;
/

 

여러 개의 IF문을 사용한 PL/SQL 구문


2. 조건문 : CASE문

/* CASE문 유형 1 */
CASE 표현식
	WHEN 결과1 THEN
    	처리문1;
    WHEN 결과2 THEN
    	처리문2;
    …
    ELSE
    	기타 처리문;
END CASE;

/* CASE문 유형 2 */
CASE -- 해당 유형을 주로 사용한다.
	WHEN 표현식1 THEN
    	처리문1;
	WHEN 표현식2 THEN
    	처리문2;
    …
    ELSE
    	기타 처리문;
END CASE;

- CASE문 예제

DECLARE
    VN_SALARY NUMBER := 0;
    VN_DEPARTMENT_ID NUMBER := 0;
BEGIN
    VN_DEPARTMENT_ID := ROUND(DBMS_RANDOM.VALUE (10, 120), -1);
    
    SELECT SALARY 
    INTO VN_SALARY
    FROM EMPLOYEES
    WHERE DEPARTMENT_ID = VN_DEPARTMENT_ID
        AND ROWNUM = 1;
    
    DBMS_OUTPUT.PUT_LINE(vn_salary);
    DBMS_OUTPUT.PUT_LINE(vn_department_id);
    
    CASE
        WHEN VN_SALARY BETWEEN 1 AND 3000 THEN
        DBMS_OUTPUT.PUT_LINE('낮음');
        WHEN VN_SALARY BETWEEN 3001 AND 6000 THEN
        DBMS_OUTPUT.PUT_LINE('중간');
        WHEN VN_SALARY BETWEEN 6001 AND 10000 THEN
        DBMS_OUTPUT.PUT_LINE('높음');
        ELSE
        DBMS_OUTPUT.PUT_LINE('최상위');
    END CASE;
END;
/

 

CASE문을 사용한 PL/SQL 구문

 

참고문헌 : 홍형경(2015), 오라클 SQL과 PL/SQL을 다루는 기술, 길벗

728x90
'▣ SQL : Database/PL SQL💾' 카테고리의 다른 글
  • [PL/SQL] PL/SQL 제어문 : CONTINUE, NULL [특정 조건 건너뛰기, 아무것도 처리하지 않기]
  • [PL/SQL] PL/SQL 제어문 : LOOP, WHILE, FOR [특정 조건에 맞을 때 반복하는 반복문]
  • [PL/SQL] PL/SQL의 구성요소 [변수와 상수, 연산자, DML문, 주석]
  • [PL/SQL] PL/SQL의 기본 구조 [PL/SQL 정의, 블록, SET SERVEROUTPUT ON, SET TMING ON]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (938) N
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (90) N
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (11) N
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    꿀팁
    백준 티어
    javascript
    CSS
    spring
    백준
    BOJ
    jsp
    Oracle
    프로그래밍
    Database
    SQL
    Error Note
    Project
    코딩
    코딩 테스트
    Java
    일상
    자바스크립트
    html
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[PL/SQL] PL/SQL 제어문 : IF, CASE [특정 조건에 맞을 때 처리하는 조건문]
상단으로

티스토리툴바