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데이터 유형은 논리 연산에 사용되는 논리 값을 저장합니다. 논리 값은 부울 값입니다.TRUEFALSE 그리고 가치 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은 하위 유형을 미리 정의합니다.CHARACTERINTEGER 다음과 같이-

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을 할당 할 수 있지만 자신을 포함하여 어떤 것과도 동일시 할 수 없습니다.