SQL
[불친절한SQL] 기초쿼리, 인코딩 디코딩 함수
Darren Gwon
2022. 12. 4. 15:14
반응형
○ 인코딩 디코딩 함수
값을 인코딩하거나 디코딩하는 함수이다.
DECODE 함수
DECODE 함수는 expr과 search가 일치하면 result, 모두 일치하지 않으면 default를 반환한다.
default를 지정하지 않으면 NULL을 반환한다.
result와 default의 데이터 타입은 첫 번째 result의 데이터 타입과 동일해야 한다.
expr과 데이터 타입이 다른 search는 expr의 데이터 타입으로 변환된다.
DECODE(expr, search, result [, search, result]··· [, default])
SELECT DECODE(1, 1, 'A', 2, 'B', 'C') AS c1
, DECODE(2, 1, 'A', 2, 'B', 'C') AS c2
, DECODE(3, 1, 'A', 2, 'B', 'C') AS c3
FROM DUAL;
SELECT DECODE('A', 1, 2 ) AS c1 FROM DUAL; --에러
SELECT DECODE(1 , 2, 1, 'A') AS c1 FROM DUAL; --에러
아래 쿼리에서 c1열은 VARCHAR2 타입, c2 열은 NUMBER 타입으로 반환한다.
DECODE 함수의 첫 번째 result가 NULL이면 VARHCAR2 타입으로 평가되기 때문이다.
SELECT DECODE(2, 1, NULL , 9) AS c1
, DECODE(2, 1, TO_NUMBER(NULL), 9) AS c2
FROM DUAL;
DECODE 함수로 NULL을 평가할 수 있지만, c2 열처럼 NVL2 함수를 사용하는 편이 좀 더 간결하다.
SELECT DECODE(1, NULL, 'A', 'B') AS c1, NVL2(1, 'B', 'A') AS c2 FROM DUAL;
아래 쿼리의 c1열은 deptno가 30이고, dname이 SALES고, loc이 CHICAGO면 Y를 반환한다.
DECODE 함수가 중첩되면 쿼리의 가독성이 나빠지고 성능이 저하될 수 있다.
결합 연산자를 사용하면 DECODE 함수의 중첩을 제거할 수 있다.
SELECT DECODE(deptno, 30, DECODE(dname, 'SALES', DECODE(loc, 'CHICAGO', 'Y'))) AS c1 FROM dept;
SELECT DECODE(deptno || dname || loc, '30SALESCHICAGO', 'Y') AS c2 FROM dept;
숫자 값에 결합 연산자를 사용하면 암시적 데이터 변환이 발생하므로
아래 쿼리처럼 CASE 표현식을 사용하는 편이 바람직하다.
SELECT CASE WHEN deptno=30 AND dname='SALES' AND loc='CHICAGO' THEN 'Y' END AS c1 FROM dept;
반응형