메뉴 건너뛰기

조회 수 8335 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

해당컬럼이 null 일때, 소스에서 처럼 if 나 switch case 문법처럼 특정조건이 맞았을때

처리하는 DB 함수들에 관한 내용이다. 첫 시작은 NVL 함수이며 이와 관련된 지식들을 
엮어 기술하였다.

1. NVL , NVL2 사용법
2. NVL 과 유사한 DECODE 사용법
3. MSSQL 에서의 CASE 문
4. ORACLE 에서의 CASE 문

 

Oracle 에서 NVL, NVL2 함수 사용하는 예제

오라클 DB 에서 데이터를 가져와 처리할 때 필드에 담긴 값이 null 인지 아닌지에 대한

판단을 하여 여러가지 처리를 하곤하는데 , 이것은 어플리케이션에 불필요한 소스를

추가하게 하는 요인이 된다.

그러므로 DB 쿼리에서 null 일때 적당한 값을 셋팅해서 처리를 해주면 소스에서 불필요한

내용을 없애줄수 있다. 그래서 많이 사용한다.

 

NVL, NVL2 함수가 그 역할을 한다, 두 함수의 차이는 NVL2 NULL 값이 아닐 때 셋팅하는

파라미터가 하나 더 있다.

 

NVL 함수 : 해당 컬럼의 null 값을 다른 값으로 치환해주는 함수

원형 : NVL (컬럼명, [null 값 대신 넣을 값])

 

NVL2 함수 : NVL 함수의 확장형으로 DECODE 함수와 유사

해당 컬럼의 값이 null 이거나 null 이 아닌 두가지 값으로 치환해준다.

원형 : NVL2 (컬럼명, [null 값이 아닐경우], [null 값일 경우])

 

NVL 함수에 대한 지식 확장 – DECODE 함수

 치환에 관련된 유사한 예제의 함수중 DECODE 가 있다.

이것은 어플리케이션의 프로그램에서 사용하는 IF 문법처럼 적용이 가능한데 특정컬럼의 값을

기준으로 해서 구분한다. 그리고 else if  처럼 특정값일 때 셋팅해야될 값을 (key, value) 쌍으로

해서 여러 개 넣을수 있다.

그리고 마지막에는 해당하는 값이 없을 때 셋팅하는 값으로 넣으면 된다. 아래 예제를 보면

쉽게 이해할수 있을 것이다.

 

SELECT dname, job

   decode(job, ‘analyst’, ‘분석가’,

   ‘clerk’, ‘점원’,

   ‘manager’, ‘관리자’,

   사원’) AS new_job

FROM emp;

 

위 쿼리를 설명하자면 job 컬럼의 값이 ‘analyst’ 이면 분석가, ‘clerk’ 이면 점원 ,
‘manager’
이면 관리자를 출력한다. 해당하는 값이 없다면 사원을 출력한다.

 

다른 사용방법으로 SUM 함수와 연계해서 특정값을 누적할수도 있다.

SUM(DECODE(Love, ’A’, 1, 0)) : love ‘A’ 와 같다면 1을 누적하고 아니면 0 을 더한다.

 

이중 DECODE 문도 허용된다. 이것은 AND 연산과 같은 작용을 하는데 두조건이 일치해야한다.

DECODE(love, ‘A’, DECODE(name, ‘KIM’, 1), 0) : love ‘A’와 같고 name ‘KIM’ 이면 1 이된다.

아니라면 0 을 가지게 되는 것이다.

이 내용을 사용한 예제가 아래와 같다. 예제를 통해 확실히 익히도록 한다.

 

SELECT EMPNAME, SUM(DECODE(SUBSTR(EMPNAME,1,3),’KIM’,1,0)

                  + DECODE(SUBSTR(EMPNAME,1,3),’LEE’,1,0))

FROM PA06MR0

WHERE SUBSTR(entondate,1,4) = ‘1998’

GROUP BY EMPNAME;

사원테이블(PA06MR0) 에서 영문성이 KIM 으로 시작하는 사람과 LEE 로 시작하는 사람의

합을 구하는데 단 입사년도가 올해 (1998) 인 사람의 합을 구하는 예제이다.


 

NVL 함수에 대한 지식 확장 – MSSQL 에서는 CASE 문을 사용한다.

NVL 을 다시 확장시켜 MSSQL 에서 비슷하게 사용하는 CASE 문에 대해 살펴본다.

문법은 다음과 같다.

Simple CASE expression;

CASE input_expression

     WHERE when_expression THEN result_expression[…n]

     [ ELSE else_result_expression]

END

Searched CASE expression;

CASE

     WHERE Boolean_expression THEN result_expression[…n]

     [ ELSE else_result_expression]

 

Oracle NVL 사용예제로 제시한 것을 CASE 문을 사용해서 바꿔보자.

SELECT dname, job

   decode(job, ‘analyst’, ‘분석가’,

   ‘clerk’, ‘점원’,

   ‘manager’, ‘관리자’,

   사원’) AS new_job

FROM emp;

 

MSSQL Case 문으로 변경했을 때 :

SELECT dname, new_job =

       CASE job

         WHEN ‘analyst’ THEN ‘분석가

         WHEN ‘clerk’ THEN ‘점원

         WHEN ‘manager’ THEN ‘관리자

         ELSE ‘사원

       END

FROM emp;

 

MSSQL CASE 확장 – Oracle 에서 CASE 문 사용예제

MSSQL 에서 사용한 문법과 동일하다. DECODE 를 사용하기 보다 Case 문을 사용하면

DB 가 바껴도 소스를 고치는 일이 없을 것이다.

원형은 다음과 같다. 설명을 붙이자면 1번은 x=y 와 같다면 a, 아니면 b 라는 것이다.

2번은 XYZ foo 이면 moo 가 되고 아니면 bar 이 된다.

1. case when x=y then a else b end

2. case XYZ when ‘foo’ then ‘moo’ else ‘bar’ end

 

예제는 다음과 같다.

SELECT a,

   CASE

      WHEN b=’*’ then ‘star’

      WHEN b=’+’ then ‘plus’

      WHEN b=’-’ then ‘minus’

      ELSE ‘????’

   END

FROM test_case_when;


List of Articles
번호 제목 날짜 조회 수
21 Oracle DB 언어셋 설정 2016.09.11 8047
20 oracle db 백업(full) 2016.09.11 9662
19 Oracle Batch Processing 2016.12.08 6822
18 Oracle 11g Database에 외부 접속 허용하도록 설정하기 file 2016.12.08 24905
17 Oracle 11g Client Install 및 외부 클라이언트 도구의 사용 file 2016.12.08 70687
16 oracle 10g - log, trc 관리 정책 스크립트 2016.09.11 10088
15 ORA-39142 덤프 버전이 틀려서 넣지 못할 때 2016.12.08 8967
14 ORA-28001: the password has expired - 추천 실적용 실전 2016.12.08 7078
13 ORA-01652 128(으)로 테이블 공간 ***에서 임시 세그먼트를 확장할 수 없습니다. file 2016.12.08 9254
12 Merge into를 이용해서 insert나 update를 자동으로 실행하자. 2016.08.29 7572
11 linux 오라클 리스너 설정(오라클 원격접속) 2016.09.11 25399
10 linux oracle 서비스 시작 및 확인 ( 간단 ) 2016.09.11 12296
9 INSTR 문자열의 뒤(마지막)에서 부터 문자 찾기 (right to left, last) file 2016.12.08 14855
8 IMP-00010: 엑스포트 파일이 유효하지 않고, 헤더가 검증에 실패했습니다 file 2016.12.08 8810
7 DB Link How-To 2016.09.12 7015
6 Database link, Synonym How to 2016.09.12 7500
5 cron을 이용한 Oracle 백업 2016.09.12 8045
4 Create SYNONYM 2016.09.12 7411
3 CLOB TEXT 데이타를 저장하고, 조회하는 예제 2016.12.08 13061
2 CentOS 6.5 에 Oracle Database 11g Release 2 설치하기 file 2016.12.08 10855
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved