Oracle 함수는 크게 단일행 함수와 복수행 함수로 구분할 수 있다.
단일행 함수 |
복수형 함수 |
하나의 행 당 하나의 결과 값을 반환 하는 함수 |
여러 개의 행 당 하나의 결과값을 반환 하는 함수 |
문자함수 |
COUNT |
숫자함수 |
SUM |
날짜함수 |
MIN / MAX |
변환함수 |
AVG |
Oracle에는 많은 함수가 존재한다. 함수는 Query가 쉬워지고 응용프로그램의 코딩을 줄여줄 수 있다
따라서 함수는 많이 알고 있으면 좋다.
가끔 쓰이는 몇가지 함수를 알아보도록 한다.
NVL2 (Column, Express1, Express2)
해당 컬럼이 NULL이면 express-1의 값을, NULL이 아니면 express-2의 값을 리턴해 줍니다.
NULLIF (Express1, Express2)
Express-1과 express-2의 값을 비교하여 그 값이 같으면 NULL을 리턴 하고 다르면 express-1의 값을 리턴해 줍니다.
COALESCE(Express1, , , , ExpressN)
Express-1이 NULL이 아니면 express-1을 리턴하고, NULL이면 express-2 를, express-1과 express-2 모두 NULL이면 express-n을 리턴해 줍니다.
TRIM ( LEADING [문자열] FROM col1 ) ;
LEADING은 왼쪽 문자열을 절삭 시켜 줍니다.
TRIM ( TRAILING [문자열] FROM col1 ) ;
TRAILING은 오른쪽 문자열을 절삭 시켜 줍니다.
TRIM ( BOTH [문자열] FROM col1 ) ;
BOTH는 양쪽 문자열을 동시에 절삭 시켜 줍니다.
SELECT 그룹함수([DISTINCT]/all]),
{column [Alias],...}
FROM 테이블명
[WHERE Query 조건(들)]
[GROUP BY 컬럼1, 컬럼2, …n]
[HAVING Group-Conditiona]
[ORDER BY 컬럼1, 컬럼2, …..[ASC/DESC]];
GROUP BY : 결과값을 지정한 컬럼을 기준으로 그룹화
HAVING : GROUP BY에 의한 결과에 대한 조건 절
ORDER BY : 결과값을 분류(Sorting)할 때