PL / SQL-데이터 유형
이 장에서는 PL / SQL의 데이터 유형에 대해 설명합니다. PL / SQL 변수, 상수 및 매개 변수에는 스토리지 형식, 제약 조건 및 유효한 값 범위를 지정하는 유효한 데이터 유형이 있어야합니다. 우리는SCALAR 그리고 LOB이 장의 데이터 유형. 다른 두 데이터 유형은 다른 장에서 다룹니다.
S. 아니 | 카테고리 및 설명 |
---|---|
1 | Scalar 내부 구성 요소가없는 단일 값 (예 : NUMBER, DATE, 또는 BOOLEAN. |
2 | Large Object (LOB) 텍스트, 그래픽 이미지, 비디오 클립 및 사운드 파형과 같은 다른 데이터 항목과 별도로 저장된 큰 개체에 대한 포인터입니다. |
삼 | Composite 개별적으로 액세스 할 수있는 내부 구성 요소가있는 데이터 항목입니다. 예를 들어, 수집 및 기록. |
4 | Reference 다른 데이터 항목에 대한 포인터. |
PL / SQL 스칼라 데이터 유형 및 하위 유형
PL / SQL 스칼라 데이터 유형 및 하위 유형은 다음 범주에 속합니다.
S. 아니 | 날짜 유형 및 설명 |
---|---|
1 | Numeric 산술 연산이 수행되는 숫자 값입니다. |
2 | Character 단일 문자 또는 문자열을 나타내는 영숫자 값입니다. |
삼 | Boolean 논리 연산이 수행되는 논리 값입니다. |
4 | Datetime 날짜와 시간. |
PL / SQL은 데이터 유형의 하위 유형을 제공합니다. 예를 들어, 데이터 유형 NUMBER에는 INTEGER라는 하위 유형이 있습니다. PL / SQL 프로그램의 하위 유형을 사용하여 Java 프로그램과 같은 다른 프로그램에 PL / SQL 코드를 임베드하는 동안 다른 프로그램의 데이터 유형과 호환되는 데이터 유형을 만들 수 있습니다.
PL / SQL 숫자 데이터 유형 및 하위 유형
다음 표는 PL / SQL 사전 정의 된 숫자 데이터 유형과 그 하위 유형을 나열합니다.
S. 아니 | 데이터 유형 및 설명 |
---|---|
1 | PLS_INTEGER -2,147,483,648에서 2,147,483,647 범위의 부호있는 정수, 32 비트로 표시 |
2 | BINARY_INTEGER -2,147,483,648에서 2,147,483,647 범위의 부호있는 정수, 32 비트로 표시 |
삼 | BINARY_FLOAT 단 정밀도 IEEE 754 형식 부동 소수점 숫자 |
4 | BINARY_DOUBLE 배정 밀도 IEEE 754 형식 부동 소수점 숫자 |
5 | NUMBER(prec, scale) 1E-130에서 1.0E126 (포함하지 않음) 범위의 절대 값을 갖는 고정 소수점 또는 부동 소수점 숫자. NUMBER 변수는 0을 나타낼 수도 있습니다. |
6 | DEC(prec, scale) 최대 정밀도가 십진수 38 자리 인 ANSI 특정 고정 소수점 유형 |
7 | DECIMAL(prec, scale) 최대 정밀도가 38 자릿수 인 IBM 특정 고정 소수점 유형 |
8 | NUMERIC(pre, secale) 최대 정밀도가 십진수 38 자리 인 부동 유형 |
9 | DOUBLE PRECISION 최대 정밀도가 126 2 진 숫자 (약 10 진수 38 자리) 인 ANSI 특정 부동 소수점 유형 |
10 | FLOAT 최대 정밀도가 126 2 진 숫자 (약 38 자리 10 진수) 인 ANSI 및 IBM 특정 부동 소수점 유형 |
11 | INT 최대 정밀도가 38 자릿수 인 ANSI 특정 정수 유형 |
12 | INTEGER 최대 정밀도가 38 자리 인 ANSI 및 IBM 특정 정수 유형 |
13 | SMALLINT 최대 정밀도가 38 자리 인 ANSI 및 IBM 특정 정수 유형 |
14 | REAL 최대 정밀도가 63 개의 2 진 숫자 (약 10 진수 18 자리) 인 부동 소수점 유형 |
다음은 유효한 선언입니다-
DECLARE
num1 INTEGER;
num2 REAL;
num3 DOUBLE PRECISION;
BEGIN
null;
END;
/
위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.
PL/SQL procedure successfully completed
PL / SQL 문자 데이터 유형 및 하위 유형
다음은 PL / SQL 사전 정의 된 문자 데이터 유형 및 하위 유형의 세부 사항입니다.
S. 아니 | 데이터 유형 및 설명 |
---|---|
1 | CHAR 최대 크기가 32,767 바이트 인 고정 길이 문자열 |
2 | VARCHAR2 최대 크기가 32,767 바이트 인 가변 길이 문자열 |
삼 | RAW 최대 크기가 32,767 바이트 인 가변 길이 바이너리 또는 바이트 문자열, PL / SQL에서 해석되지 않음 |
4 | NCHAR 최대 크기가 32,767 바이트 인 고정 길이 국가 별 문자열 |
5 | NVARCHAR2 최대 크기가 32,767 바이트 인 가변 길이 국가 별 문자열 |
6 | LONG 최대 크기가 32,760 바이트 인 가변 길이 문자열 |
7 | LONG RAW 최대 크기가 32,760 바이트 인 가변 길이 바이너리 또는 바이트 문자열, PL / SQL로 해석되지 않음 |
8 | ROWID 물리적 행 식별자, 일반 테이블의 행 주소 |
9 | UROWID 범용 행 식별자 (물리적, 논리적 또는 외부 행 식별자) |
PL / SQL 부울 데이터 유형
그만큼 BOOLEAN데이터 유형은 논리 연산에 사용되는 논리 값을 저장합니다. 논리 값은 부울 값입니다.TRUE 과 FALSE 그리고 가치 NULL.
그러나 SQL에는 BOOLEAN에 해당하는 데이터 유형이 없습니다. 따라서 부울 값은-
- SQL 문
- 내장 SQL 함수 (예 : TO_CHAR)
- SQL 문에서 호출되는 PL / SQL 함수
PL / SQL 날짜 / 시간 및 간격 유형
그만큼 DATE데이터 유형은 자정 이후의 시간 (초)을 포함하는 고정 길이 날짜 시간을 저장하는 데 사용됩니다. 유효한 날짜 범위는 BC 4712 년 1 월 1 일부터 AD 9999 년 12 월 31 일까지입니다.
기본 날짜 형식은 Oracle 초기화 매개 변수 NLS_DATE_FORMAT에 의해 설정됩니다. 예를 들어, 기본값은 'DD-MON-YY'일 수 있으며, 여기에는 날짜에 대한 두 자리 숫자, 월 이름의 약어 및 연도의 마지막 두 자리가 포함됩니다. 예 : 01-OCT-12.
각 DATE에는 세기, 연도, 월, 일,시, 분 및 초가 포함됩니다. 다음 표는 각 필드의 유효한 값을 보여줍니다-
분야 명 | 유효한 날짜 / 시간 값 | 유효한 간격 값 |
---|---|---|
년 | -4712 ~ 9999 (0 년 제외) | 0이 아닌 정수 |
달 | 01에서 12 | 0에서 11 |
일 | 01 ~ 31 (로케일의 달력 규칙에 따라 MONTH 및 YEAR 값으로 제한됨) | 0이 아닌 정수 |
시 | 00에서 23 | 0에서 23 |
분 | 00에서 59 | 0에서 59 |
둘째 | 00 ~ 59.9 (n), 여기서 9 (n)은 시간 분수 초의 정밀도입니다. | 0 ~ 59.9 (n), 여기서 9 (n)은 간격 분수 초의 정밀도입니다. |
TIMEZONE_HOUR | -12 ~ 14 (일광 절약 시간 변경을 수용하는 범위) | 해당 없음 |
TIMEZONE_MINUTE | 00에서 59 | 해당 없음 |
TIMEZONE_REGION | 동적 성능보기 V $ TIMEZONE_NAMES에서 찾았습니다. | 해당 없음 |
TIMEZONE_ABBR | 동적 성능보기 V $ TIMEZONE_NAMES에서 찾았습니다. | 해당 없음 |
PL / SQL LOB (Large Object) 데이터 유형
LOB (Large Object) 데이터 유형은 텍스트, 그래픽 이미지, 비디오 클립 및 사운드 파형과 같은 대형 데이터 항목을 나타냅니다. LOB 데이터 유형은이 데이터에 대한 효율적이고 무작위적인 부분 액세스를 허용합니다. 다음은 사전 정의 된 PL / SQL LOB 데이터 유형입니다-
데이터 형식 | 기술 | 크기 |
---|---|---|
BFILE | 데이터베이스 외부의 운영 체제 파일에 큰 이진 개체를 저장하는 데 사용됩니다. | 시스템에 따라 다릅니다. 4GB를 초과 할 수 없습니다. |
얼룩 | 데이터베이스에 큰 이진 개체를 저장하는 데 사용됩니다. | 8 ~ 128TB (테라 바이트) |
CLOB | 데이터베이스에 큰 문자 데이터 블록을 저장하는 데 사용됩니다. | 8 ~ 128TB |
NCLOB | 데이터베이스에 NCHAR 데이터의 큰 블록을 저장하는 데 사용됩니다. | 8 ~ 128TB |
PL / SQL 사용자 정의 하위 유형
하위 유형은 기본 유형이라고하는 다른 데이터 유형의 하위 집합입니다. 하위 유형에는 기본 유형과 동일한 유효한 작업이 있지만 유효한 값의 하위 집합 만 있습니다.
PL / SQL은 패키지의 여러 하위 유형을 미리 정의합니다. STANDARD. 예를 들어 PL / SQL은 하위 유형을 미리 정의합니다.CHARACTER 과 INTEGER 다음과 같이-
SUBTYPE CHARACTER IS CHAR;
SUBTYPE INTEGER IS NUMBER(38,0);
고유 한 하위 유형을 정의하고 사용할 수 있습니다. 다음 프로그램은 사용자 정의 하위 유형을 정의하고 사용하는 방법을 보여줍니다-
DECLARE
SUBTYPE name IS char(20);
SUBTYPE message IS varchar2(100);
salutation name;
greetings message;
BEGIN
salutation := 'Reader ';
greetings := 'Welcome to the World of PL/SQL';
dbms_output.put_line('Hello ' || salutation || greetings);
END;
/
위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.
Hello Reader Welcome to the World of PL/SQL
PL/SQL procedure successfully completed.
PL / SQL의 NULL
PL / SQL NULL 값은 missing 또는 unknown data정수, 문자 또는 기타 특정 데이터 유형이 아닙니다. 참고NULL 빈 데이터 문자열 또는 널 문자 값과 동일하지 않습니다. '\0'. null을 할당 할 수 있지만 자신을 포함하여 어떤 것과도 동일시 할 수 없습니다.