전체/Oracle
ORACLE ESCAPE, NVL, NVL2, ORDER BY, DISTINCT 정리
effortDev
2017. 6. 12. 13:02
LIKE/%/ESCAPE/IS NULL/IS NOT NULL/ORDER BY/ASC/DISTINCT
NULL인 컬럼을 추출하는 연산자와 ORDER BY 절을 이용하여 특정 컬럼에 대해 정렬과 DISTINCT/별칭/연결 연산자
1. ESCAPE
ESCAPE는 %(퍼센트)나 _(언더바)가 같이 특수문자를 조건 안에 넣기 위해 사용한다.
만약 LIKE 연산자로 '%SAMPLE', 'SAM%PLE', 'SAMPLE%' 라는 단어를 찾을때 %나 _인 문자를 어떻게 찾을것인가?
SELECT
*
FROM
EMP
WHERE
JOB
LIKE
'S%'
SELECT
*
FROM
EMP
WHERE
JOB
LIKE
'%S'
위와 같은 방식으로 찾기 어렵다는 한계 발견하였다.
다음과 같이 ESCAPE를 사용해 해당하는 단어를 추출할수 있다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | --테스트 위해 샘플 데이터 INSERT SELECT * FROM DEPT INSERT INTO DEPT VALUES(50,'MY','NEW_YORK') INSERT INTO DEPT VALUES(60,'MY2','NEW%YORK') --'_' 가 있는 문자 검색 -1 SELECT LOC FROM DEPT WHERE LOC LIKE '%#_%' ESCAPE '#' --'_' 가 있는 문자 검색 -2 SELECT LOC FROM DEPT WHERE LOC LIKE '%N%@_%' ESCAPE '@' --'%' 가 있는 문자 검색 -1 SELECT LOC FROM DEPT WHERE LOC LIKE '%@%%' ESCAPE '@' | cs |
2. IS NULL / IS NOT NULL
NVL
사용 방법 : NVL(expr, expr1)
NVL 함수는 NULL 값을 다른 값으로 바꿀 때 사용하며, 모든 데이터 타입에 적용이 가능하다.
1 2 3 4 5 6 | SELECT EMPNO , ENAME , JOB , NVL(MGR,0) AS MGR --MGR이 없는 경우(NULL) , NVL(COMM,0) AS COMM --COMM이 없는 경우(NULL) FROM EMP | cs |
NVL2
사용 방법 : NVL2(expr, expr1, expr2)
NVL2라는 함수는 NVL함수의 DECODE 함수의 개념을 합쳤다고 생각하면 쉽다.
expr의 값이 NULL이 아닐 경우에는 expr1의 값을 반환 하고, NULL일 경우에는 expr2의 값을 반환 한다.
1 2 3 4 5 6 | SELECT EMPNO , NVL2(ENAME,ENAME,0) AS ENAME , NVL2(JOB,JOB,0) AS JOB , NVL2(MGR,MGR,0) AS MGR , NVL2(COMM,COMM,0) AS COMM FROM EMP | cs |
3. ORDER BY
컬럼 값을 기준으로 정렬할 때 사용한다.
1 2 3 4 5 6 7 | SELECT * FROM EMP ORDER BY SAL -- 오름차순 정렬 SELECT * FROM EMP ORDER BY SAL DESC -- 내림차순 정렬 | cs |
4. DISTINCT
조회하려는 칼럼의 중복되는 값은 제거 후 보여준다.
DISTINCT 키워드 뒤에 2개 이상의 칼럼을 정의하면 하나의 RECORD로 인식하여 DISTINCT 키워드 이후에 오는 칼럼에 대해 모두 중복 제거한다.
1 2 | SELECT DISTINCT JOB FROM EMP | cs |
출력 결과