변환 기능 사용
SQL 유틸리티 함수 외에도 Oracle 내장 함수 라이브러리에는 유형 변환 함수가 포함되어 있습니다. 쿼리가 특정 데이터 유형의 입력을 예상하지만 다른 데이터 유형으로 수신하는 시나리오가있을 수 있습니다. 이러한 경우 Oracle은 예상치 못한 값을 제자리에서 대체 할 수있는 호환 가능한 데이터 유형으로 암시 적으로 변환하려고 시도하며 애플리케이션 연속성이 손상되지 않습니다. 유형 변환은 Oracle에 의해 암시 적으로 수행되거나 프로그래머에 의해 명시 적으로 수행 될 수 있습니다.
암시 적 데이터 유형 변환은 내부 유형 캐스팅에 대한 Oracle의 지원을 보여주는 매트릭스를 기반으로 작동합니다. 이러한 규칙 외에도 Oracle은 명시 적 변환 및 형식화를위한 쿼리에서 사용할 수있는 유형 변환 기능을 제공합니다. 사실 소프트웨어 인텔리전스에 의존하는 대신 명시 적 변환을 수행하는 것이 좋습니다. 암시 적 변환은 잘 작동하지만 잘못된 입력이 내부적으로 형변환하기 어려울 수있는 왜곡 가능성을 제거합니다.
암시 적 데이터 유형 변환
VARCHAR2 또는 CHAR 값은 Oracle에 의해 암시 적으로 NUMBER 또는 DATE 유형 값으로 변환 될 수 있습니다. 마찬가지로 NUMBER 또는 DATA 유형 값은 Oracle 서버에 의해 문자 데이터로 자동 변환 될 수 있습니다. impicit 상호 변환은 문자가 각각 유효한 숫자 또는 날짜 유형 값을 나타내는 경우에만 발생합니다.
예를 들어, 아래 SELECT 쿼리를 검토하십시오. Oracle은 내부적으로 15000과 '15000'을 동일하게 취급하기 때문에 두 쿼리 모두 동일한 결과를 제공합니다.
쿼리 -1
SELECT employee_id,first_name,salary
FROM employees
WHERE salary > 15000;
쿼리 -2
SELECT employee_id,first_name,salary
FROM employees
WHERE salary > '15000';
명시 적 데이터 유형 변환
SQL 변환 함수는 열 값, 리터럴 또는 표현식을 형변환 할 수있는 단일 행 함수입니다. TO_CHAR, TO_NUMBER 및 TO_DATE는 데이터 유형의 교차 수정을 수행하는 세 가지 함수입니다.
TO_CHAR 함수
TO_CHAR 함수는 형식 모델 (선택 사항)을 사용하여 숫자 또는 날짜 입력을 문자 유형으로 형변환하는 데 사용됩니다.
통사론
TO_CHAR(number1, [format], [nls_parameter])
숫자를 문자로 변환하는 경우 nls 매개 변수를 사용하여 10 진수 문자, 그룹 구분 기호, 현지 통화 모델 또는 국제 통화 모델을 지정할 수 있습니다. 선택 사양입니다. 사용할 수없는 경우 세션 수준 nls 설정이 사용됩니다. 날짜를 문자로 변환하는 경우 nls 매개 변수를 사용하여 해당되는 경우 일 및 월 이름을 지정할 수 있습니다.
TO_CHAR 함수를 사용하여 문자 유형으로 변환 한 후 날짜를 여러 형식으로 포맷 할 수 있습니다. TO_CHAR 함수는 Oracle 11g가 특정 형식으로 날짜를 표시하는 데 사용됩니다. 형식 모델은 대소 문자를 구분하며 작은 따옴표로 묶어야합니다.
아래 SELECT 쿼리를 고려하십시오. 쿼리 형식은 TO_CHAR 함수를 사용하여 EMPLOYEES 테이블의 HIRE_DATE 및 SALARY 열입니다.
SELECT first_name,
TO_CHAR (hire_date, 'MONTH DD, YYYY') HIRE_DATE,
TO_CHAR (salary, '$99999.99') Salary
FROM employees
WHERE rownum < 5;
FIRST_NAME HIRE_DATE SALARY
-------------------- ------------------ ----------
Steven JUNE 17, 2003 $24000.00
Neena SEPTEMBER 21, 2005 $17000.00
Lex JANUARY 13, 2001 $17000.00
Alexander JANUARY 03, 2006 $9000.00
첫 번째 TO_CHAR은 고용 날짜를 날짜 형식 MONTH DD, YYYY로 변환하는 데 사용됩니다. 즉, 철자가 공백으로 채워져있는 월, 그 뒤에 두 자리 일, 그리고 네 자리 연도를 차례로 표시합니다. 월 이름을 대소 문자 혼합 (즉, "December")으로 표시하는 것을 선호하는 경우 형식 인수에 다음 대소 문자를 사용하십시오 : ( 'Month DD, YYYY').
그림 10-39의 두 번째 TO_CHAR 함수는 SALARY를 형식화하여 통화 기호와 두 개의 소수점 자리를 표시하는 데 사용됩니다.
오라클은 포괄적 인 형식 모델 세트를 제공합니다. 아래 표는 TO_CHAR을 사용하여 날짜 및 숫자 값을 문자로 형변환하는 데 사용할 수있는 형식 모델 목록입니다.
형식 모델 | 기술 |
---|---|
,(반점) | 지정된 위치에 쉼표를 반환합니다. 숫자 형식 모델에 여러 쉼표를 지정할 수 있습니다. 제한 사항 : 쉼표 요소는 숫자 형식 모델을 시작할 수 없습니다. 숫자 형식 모델에서 10 진수 문자 또는 마침표 오른쪽에는 쉼표를 표시 할 수 없습니다. |
.(기간) | 지정된 위치의 마침표 (.) 인 소수점을 반환합니다. 제한 사항 : 숫자 형식 모델에서 하나의 마침표 만 지정할 수 있습니다. |
$ | 선행 달러 기호가있는 값을 반환합니다. |
0 | 선행 0을 반환합니다. 후행 0을 반환합니다. |
9 | 양수인 경우 선행 공백을 사용하고 음수 인 경우 선행 마이너스를 사용하여 지정된 자릿수의 값을 반환합니다. 고정 소수점 숫자의 정수 부분에 대해 0을 반환하는 0 값을 제외하고 선행 0은 공백입니다. |
비 | 정수 부분이 0 일 때 고정 소수점 숫자의 정수 부분에 대해 공백을 리턴합니다 (형식 모델의 "0"에 관계없이). |
씨 | 지정된 위치에 ISO 통화 기호 (NLS_ISO_CURRENCY 매개 변수의 현재 값)를 리턴합니다. |
디 | NLS_NUMERIC_CHARACTER 매개 변수의 현재 값인 10 진수 문자를 지정된 위치에 반환합니다. 기본값은 마침표 (.)입니다. 제한 사항 : 숫자 형식 모델에서는 하나의 10 진수 문자 만 지정할 수 있습니다. |
EEE | 과학적 표기법을 사용하여 값을 반환합니다. |
FM | 선행 또는 후행 공백이없는 값을 리턴합니다. |
지 | 지정된 위치에 그룹 구분 기호 (NLS_NUMERIC_CHARACTER 매개 변수의 현재 값)를 반환합니다. 숫자 형식 모델에서 여러 그룹 구분 기호를 지정할 수 있습니다. 제한 사항 : 그룹 구분 기호는 숫자 형식 모델에서 소수 문자 또는 마침표 오른쪽에 나타날 수 없습니다. |
엘 | 지정된 위치에 현지 통화 기호 (NLS_CURRENCY 매개 변수의 현재 값)를 반환합니다. |
미 | 후행 마이너스 기호 (-)와 함께 음수 값을 반환합니다. 후행 공백이있는 양수 값을 반환합니다. 제한 사항 : MI 형식 요소는 숫자 형식 모델의 마지막 위치에만 나타날 수 있습니다. |
PR | 에서 음수 값을 반환합니다. 숫자 형식 모델의 끝에 만 나타날 수 있습니다. |
RN, rm | 값을 대문자로 된 로마 숫자로 반환합니다. 값을 소문자 로마 숫자로 반환합니다. 값은 1에서 3999 사이의 정수일 수 있습니다. |
에스 | 선행 또는 후행 마이너스 기호 (-)와 함께 음수 값을 반환합니다. 선행 또는 후행 더하기 기호 (+)와 함께 양수 값을 반환합니다. 제한 사항 : S 형식 요소는 숫자 형식 모델의 첫 번째 또는 마지막 위치에만 나타날 수 있습니다. |
TM | "최소 텍스트". 가능한 최소 문자 수를 10 진수 출력으로 반환합니다. 이 요소는 대소 문자를 구분하지 않습니다. |
유 | 지정된 위치에 "Euro"(또는 기타) 이중 통화 기호 (NLS_DUAL_CURRENCY 매개 변수의 현재 값)를 반환합니다. |
V | 10n을 곱한 값을 반환합니다 (필요한 경우 반올림). 여기서 n은 "V"뒤에 오는 9의 수입니다. |
엑스 | 지정된 자릿수의 16 진수 값을 반환합니다. |
TO_NUMBER 함수
TO_NUMBER 함수는 문자 값을 숫자 데이터 유형으로 변환합니다. 변환중인 문자열에 숫자가 아닌 문자가 포함 된 경우 함수는 오류를 반환합니다.
통사론
TO_NUMBER (string1, [format], [nls_parameter])
아래 표는 TO_NUMBER를 사용하여 문자 값을 숫자로 형변환하는 데 사용할 수있는 형식 모델 목록입니다.
형식 모델 | 기술 |
---|---|
CC | 세기 |
SCC | BC 세기-접두사 |
YYYY | 4 자리 숫자가있는 연도 |
SYYY | BC 연도 앞에- |
IYYY | 4 개의 숫자가있는 ISO 연도 |
YY | 2 개의 숫자가있는 연도 |
RR | Y2k와 호환되는 2 개의 숫자가있는 해 |
년 | 문자 연도 |
SYEAR | 연도 문자, BC 접두사- |
기원전 | BC / AD 표시기 |
큐 | 숫자의 분기 (1,2,3,4) |
MM | 01, 02 ... 12의 달 |
달 | 월 (예 : 1 월) |
월 | 2 월 1 일 |
W W | 주 번호 (예 : 1) |
W | 월의 주 번호 (예 : 5) |
IW | ISO 표준에서 연중 주 번호입니다. |
DDD | 숫자로 본 연중 일 (예 : 365) |
DD | 숫자로 나타낸 날짜 (예 : 28) |
디 | 숫자로 나타낸 요일 (예 : 7) |
일 | 요일 (예 : 월요일) |
FMDAY | 요일 (예 : 월요일) |
DY | 짧은 문자 설명 (예 : SUN)의 요일 |
제이 | 율리우스 력의 날 (BC 4713 년 1 월 1 일 이후의 일수, 여기서 1 월 1 일 4713 BC는 Oracle에서 1) |
HH, H12 | 시간 (1-12) |
HH24 | 24 시간 표기법 (0-23)의 시간 수 |
오전 오후 | 오전 아니면 오후 |
MI, SS | 분 및 초 수 (예 : 59), |
SSSSS | 오늘의 시간 (초)입니다. |
DS | 짧은 날짜 형식. NLS 설정에 따라 다릅니다. 타임 스탬프에만 사용하십시오. |
DL | 긴 날짜 형식. NLS 설정에 따라 다릅니다. 타임 스탬프에만 사용하십시오. |
이자형 | 축약 된 연대 이름입니다. 달력에만 유효합니다 : 일본 제국, ROC 공식, 태국 부처님. |
EE | 전체 시대 이름 |
FF | 소수 초입니다. 타임 스탬프와 함께 사용합니다. |
FF1..FF9 | 소수 초입니다. 타임 스탬프와 함께 사용합니다. 숫자는 분수 초에 사용되는 소수 자릿수를 제어합니다. |
FM | 채우기 모드 : 변환에서 출력의 공백을 억제합니다. |
FX | 정확한 형식 : 데이터와 형식 모델간에 정확한 패턴 일치가 필요합니다. |
IYY 또는 IY 또는 I | ISO 표준 연도의 마지막 3,2,1 자리입니다. 출력 만 |
RM | 월의 로마 숫자 표현 (I .. XII) |
RR | 연도의 마지막 2 자리입니다. |
RRRR | 출력에 사용되는 연도의 마지막 2 자리입니다. 입력에 사용될 때 fout-digit 연도를 허용합니다. |
SP | 철자 형식. 숫자 요소의 끝에 나타날 수 있습니다. 결과는 항상 영어입니다. 예를 들어 MMSP 형식의 10 개월은 "10"을 반환합니다. |
SPTH | 철자와 서수 형식; 1은 1 위입니다. |
TH | 숫자를 서수 형식으로 변환합니다. 예를 들어 1이 1이됩니다. |
TS | 짧은 시간 형식. NLS 설정에 따라 다릅니다. 타임 스탬프에만 사용하십시오. |
TZD | 약식 시간대 이름입니다. 즉 PST. |
TZH, TZM | 시간대시 / 분 변위. |
TZR | 시간대 지역 |
엑스 | 로컬 기수 문자. 미국에서는 마침표 (.) |
아래 SELECT 쿼리는 숫자를 문자 입력으로 받아들이고 형식 지정자에 따라 인쇄합니다.
SELECT TO_NUMBER('121.23', '9G999D99')
FROM DUAL
TO_NUMBER('121.23','9G999D99')
------------------------------
121.23
SELECT TO_NUMBER('1210.73', '9999.99')
FROM DUAL;
TO_NUMBER('1210.73','9999.99')
------------------------------
1210.73
TO_DATE 함수
이 함수는 문자 값을 입력으로 받아 동일한 형식의 날짜를 반환합니다. TO_DATE 함수를 사용하면 사용자가 모든 형식으로 날짜를 입력 할 수 있으며 항목을 Oracle 11g에서 사용하는 기본 형식으로 변환합니다.
통사론:
TO_DATE( string1, [ format_mask ], [ nls_language ] )
format_mask 인수는 데이터의 모양을 정확히 나타내는 일련의 요소로 구성되며 작은 따옴표로 입력해야합니다.
형식 모델 | 기술 |
---|---|
년 | 연도, 철자 |
YYYY | 4 자리 연도 |
YYY, YY, Y | 연도의 마지막 3, 2 또는 1 자리 숫자입니다. |
IYY, IY, I | ISO 연도의 마지막 3, 2 또는 1 자리 숫자입니다. |
IYYY | ISO 표준에 따른 4 자리 연도 |
RRRR | 2 자리 연도를 허용하고 4 자리 연도를 반환합니다. |
큐 | 분기 (1, 2, 3, 4, 1 월 -MAR = 1). |
MM | 월 (01-12, JAN = 01). |
월 | 월의 약칭입니다. |
달 | 9 자 길이까지 공백으로 채워진 월 이름입니다. |
RM | 로마 숫자 월 (I-XII, JAN = I). |
W W | 1 주가 1 년의 첫 번째 날에 시작하여 연중 7 일까지 계속되는 연도의 주 (1-53)입니다. |
W | 주 1이 해당 월의 1 일에 시작하여 7 일에 끝나는 월의 주 (1-5). |
IW | ISO 표준에 따른 주 (1-52 또는 1-53)입니다. |
디 | 요일 (1-7). |
일 | 요일의 이름. |
DD | 날짜 (1-31). |
DDD | 연중 일 (1-366). |
DY | 요일의 약식 이름입니다. |
제이 | 줄리안 데이; 기원전 4712 년 1 월 1 일 이후의 일수. |
HH12 | 시간 (1-12). |
HH24 | 시간 (0-23). |
미스 | 분 (0-59). |
SSSSS | 자정 이후 초 (0-86399). |
FF | 몇 초입니다. 소수 초의 자릿수를 표시하려면 FF 뒤에 1에서 9 사이의 값을 사용하십시오. 예 : 'FF4'. |
오전 오후 | 자오선 표시기 |
AD, BC | AD, BC 표시기 |
TZD | 일광 절약 정보. 예 : 'PST' |
TZH, TZM, TZR | 시간대시 / 분 / 지역. |
다음 예제는 문자열을 날짜로 변환합니다.
SELECT TO_DATE('January 15, 1989, 11:00 A.M.', 'Month dd, YYYY, HH:MI A.M.', 'NLS_DATE_LANGUAGE = American')
FROM DUAL;
TO_DATE('
---------
15-JAN-89
일반 기능
일반 함수는 데이터베이스에서 NULL 값을 처리하는 데 사용됩니다. 일반 NULL 처리 함수의 목적은 NULL 값을 대체 값으로 바꾸는 것입니다. 아래에서 이러한 기능을 간략하게 살펴 보겠습니다.
NVL
NVL 함수는 NULL 값을 대체 값으로 대체합니다.
통사론:
NVL( Arg1, replace_with )
구문에서 두 매개 변수는 모두 필수입니다. NVL 함수는 모든 유형의 데이터 유형에서 작동합니다. 또한 원본 문자열의 데이터 유형과 교체는 호환 가능한 상태 여야합니다. 즉, Oracle이 동일하거나 암시 적으로 변환 할 수 있어야합니다.
arg1이 문자 값이면 oracle은 대체 문자열을 비교하기 전에 arg1과 호환되는 데이터 유형으로 변환하고 expr1의 문자 집합에 VARCHAR2를 반환합니다. arg1이 숫자이면 Oracle은 숫자 우선 순위가 가장 높은 인수를 결정하고 다른 인수를 해당 데이터 형식으로 암시 적으로 변환 한 다음 해당 데이터 형식을 반환합니다.
아래 SELECT 문은 직원이 아직 작업에 할당되지 않은 경우 (즉, JOB_ID가 NULL 인 경우) 'n / a'를 표시합니다. 그렇지 않으면 실제 JOB_ID 값이 표시됩니다.
SELECT first_name, NVL(JOB_ID, 'n/a')
FROM employees;
NVL2
NVL에 대한 개선 사항으로 Oracle은 NULL 열 값뿐만 아니라 NOT NULL 열 값을 대체하는 기능을 도입했습니다. NVL2 함수는 NULL이 아닌 값뿐만 아니라 NULL을 대체 값으로 대체하는 데 사용할 수 있습니다.
통사론:
NVL2( string1, value_if_NOT_null, value_if_null )
아래 SELECT 문은 직원의 JOB_CODE가 NULL 인 경우 'Bench'를 표시합니다. JOB CODE의 명확한 null이 아닌 값의 경우 상수 값 'Job Assigned'가 표시됩니다.
SQL> SELECT NVL2(JOB_CODE, 'Job Assigned', 'Bench')
FROM employees;
NULLIF
NULLIF 함수는 두 인수 expr1 및 expr2를 비교합니다. expr1과 expr2가 같으면 NULL을 반환합니다. 그렇지 않으면 expr1을 반환합니다. 다른 null 처리 함수와 달리 첫 번째 인수는 NULL이 될 수 없습니다.
통사론:
NULLIF (expr1, expr2)
첫 번째 인수는 NULL로 평가되는 표현식 일 수 있지만 리터럴 NULL 일 수는 없습니다. 함수를 실행하려면 두 매개 변수가 모두 필수입니다.
아래 쿼리는 두 입력 값 12가 같으므로 NULL을 반환합니다.
SELECT NULLIF (12, 12)
FROM DUAL;
마찬가지로 아래 쿼리는 두 문자열이 같지 않기 때문에 'SUN'을 반환합니다.
SELECT NULLIF ('SUN', 'MOON')
FROM DUAL;
COALESCE
보다 일반적인 형식의 NVL 인 COALESCE 함수는 인수 목록에서 null이 아닌 첫 번째 식을 반환합니다. 최소 2 개의 필수 매개 변수를 사용하지만 최대 인수에는 제한이 없습니다.
통사론:
COALESCE (expr1, expr2, ... expr_n )
아래 SELECT 쿼리를 고려하십시오. 직원의 주소 필드에 입력 된 첫 번째 null이 아닌 값을 선택합니다.
SELECT COALESCE (address1, address2, address3) Address
FROM employees;
흥미롭게도 COALESCE 함수의 작동은 IF..ELSIF..ENDIF 구조와 유사합니다. 위의 쿼리는 다음과 같이 다시 작성할 수 있습니다.
IF address1 is not null THEN
result := address1;
ELSIF address2 is not null THEN
result := address2;
ELSIF address3 is not null THEN
result := address3;
ELSE
result := null;
END IF;
조건부 함수
Oracle은 SQL 문에서도 조건을 부과하는 조건부 함수 DECODE 및 CASE를 제공합니다.
DECODE 기능
함수는 IF..THEN..ELSE 조건부 프로 시저 명령문의 SQL 동등성입니다. DECODE는 모든 데이터 유형의 값 / 열 / 표현식에서 작동합니다.
통사론:
DECODE (expression, search, result [, search, result]... [, default])
DECODE 함수는 각 검색 값에 대해 표현식을 순서대로 비교합니다. 표현식과 검색 인수가 같으면 해당 결과를 반환합니다. 일치하지 않는 경우 정의 된 경우 기본값이 반환되고 그렇지 않은 경우 NULL이 반환됩니다. 유형 호환성이 일치하지 않는 경우 Oracle은 내부적으로 가능한 암시 적 변환을 수행하여 결과를 반환합니다.
사실 Oracle은 DECODE 기능으로 작업하는 동안 두 개의 null을 동등한 것으로 간주합니다.
SELECT DECODE(NULL,NULL,'EQUAL','NOT EQUAL')
FROM DUAL;
DECOD
-----
EQUAL
expression이 null이면 Oracle은 null 인 첫 번째 검색의 결과를 반환합니다. DECODE 기능의 최대 구성 요소 수는 255입니다.
SELECT first_name, salary, DECODE (hire_date, sysdate,'NEW JOINEE','EMPLOYEE')
FROM employees;
CASE 표현식
CASE 표현식은 DECODE와 동일한 개념으로 작동하지만 구문과 사용법이 다릅니다.
통사론:
CASE [ expression ]
WHEN condition_1 THEN result_1
WHEN condition_2 THEN result_2
...
WHEN condition_n THEN result_n
ELSE result
END
Oracle 검색은 왼쪽에서 시작하여 참 조건을 찾을 때까지 오른쪽으로 이동 한 다음 그와 관련된 결과 표현식을 반환합니다. 참인 조건이없고 ELSE 절이 존재하면 Oracle은 else로 정의 된 결과를 반환합니다. 그렇지 않으면 Oracle은 null을 반환합니다.
CASE 표현식의 최대 인수 수는 255 개입니다. 단순 CASE 표현식의 초기 표현식 및 선택적 ELSE 표현식을 포함하여 모든 표현식이이 제한에 포함됩니다. 각 WHEN ... THEN 쌍은 두 개의 인수로 계산됩니다. 이 제한을 초과하지 않으려면 return_expr 자체가 CASE 표현식이되도록 CASE 표현식을 중첩 할 수 있습니다.
SELECT first_name, CASE WHEN salary < 200 THEN 'GRADE 1'
WHEN salary > 200 AND salary < 5000 THEN 'GRADE 2'
ELSE 'GRADE 3'
END CASE
FROM employees;
ENAM CASE
---- -------
JOHN GRADE 2
EDWIN GRADE 3
KING GRADE 1