PL / SQL-빠른 가이드

PL / SQL 프로그래밍 언어는 1980 년대 후반에 Oracle Corporation에서 SQL 및 Oracle 관계형 데이터베이스를위한 절차 적 확장 언어로 개발했습니다. 다음은 PL / SQL에 대한 주목할만한 사실입니다.

  • PL / SQL은 완전히 이식 가능한 고성능 트랜잭션 처리 언어입니다.

  • PL / SQL은 내장, 해석 및 OS 독립적 프로그래밍 환경을 제공합니다.

  • PL / SQL은 명령 줄에서 직접 호출 할 수도 있습니다. SQL*Plus interface.

  • 데이터베이스에 대한 외부 프로그래밍 언어 호출에서 직접 호출 할 수도 있습니다.

  • PL / SQL의 일반 구문은 ADA 및 Pascal 프로그래밍 언어의 구문을 기반으로합니다.

  • Oracle 외에도 PL / SQL은 TimesTen in-memory databaseIBM DB2.

PL / SQL의 기능

PL / SQL에는 다음과 같은 기능이 있습니다.

  • PL / SQL은 SQL과 긴밀하게 통합됩니다.
  • 광범위한 오류 검사를 제공합니다.
  • 다양한 데이터 유형을 제공합니다.
  • 다양한 프로그래밍 구조를 제공합니다.
  • 기능과 절차를 통해 구조화 된 프로그래밍을 지원합니다.
  • 객체 지향 프로그래밍을 지원합니다.
  • 웹 애플리케이션 및 서버 페이지의 개발을 지원합니다.

PL / SQL의 장점

PL / SQL에는 다음과 같은 장점이 있습니다.

  • SQL은 표준 데이터베이스 언어이며 PL / SQL은 SQL과 강력하게 통합됩니다. PL / SQL은 정적 및 동적 SQL을 모두 지원합니다. 정적 SQL은 PL / SQL 블록에서 DML 작업 및 트랜잭션 제어를 지원합니다. 동적 SQL에서 SQL은 PL / SQL 블록에 DDL 문을 포함 할 수 있습니다.

  • PL / SQL을 사용하면 한 번에 전체 문 블록을 데이터베이스로 보낼 수 있습니다. 이는 네트워크 트래픽을 줄이고 애플리케이션에 고성능을 제공합니다.

  • PL / SQL은 데이터베이스의 데이터를 쿼리, 변환 및 업데이트 할 수 있으므로 프로그래머에게 높은 생산성을 제공합니다.

  • PL / SQL은 예외 처리, 캡슐화, 데이터 숨김 및 객체 지향 데이터 유형과 같은 강력한 기능을 통해 설계 및 디버깅 시간을 절약합니다.

  • PL / SQL로 작성된 애플리케이션은 완전히 이식 가능합니다.

  • PL / SQL은 높은 보안 수준을 제공합니다.

  • PL / SQL은 사전 정의 된 SQL 패키지에 대한 액세스를 제공합니다.

  • PL / SQL은 객체 지향 프로그래밍을 지원합니다.

  • PL / SQL은 웹 응용 프로그램 및 서버 페이지 개발을 지원합니다.

이 장에서는 PL / SQL의 환경 설정에 대해 설명합니다. PL / SQL은 독립형 프로그래밍 언어가 아닙니다. Oracle 프로그래밍 환경 내의 도구입니다.SQL* Plus명령 프롬프트에서 SQL 및 PL / SQL 문을 입력 할 수있는 대화 형 도구입니다. 이러한 명령은 처리를 위해 데이터베이스로 전송됩니다. 명세서가 처리되면 결과가 다시 전송되어 화면에 표시됩니다.

PL / SQL 프로그램을 실행하려면 시스템에 Oracle RDBMS Server가 설치되어 있어야합니다. 이것은 SQL 명령의 실행을 처리합니다. Oracle RDBMS의 최신 버전은 11g입니다. 다음 링크에서 Oracle 11g 평가판을 다운로드 할 수 있습니다.

Oracle 11g Express Edition 다운로드

운영 체제에 따라 32 비트 또는 64 비트 버전의 설치를 다운로드해야합니다. 일반적으로 두 개의 파일이 있습니다. 64 비트 버전을 다운로드했습니다. 또한 운영 체제에서 유사한 단계를 사용하며 Linux 또는 Solaris인지는 중요하지 않습니다.

  • win64_11gR2_database_1of2.zip

  • win64_11gR2_database_2of2.zip

위의 두 파일을 다운로드 한 후 단일 디렉토리에 압축을 풀어야합니다. database 그 아래에 다음과 같은 하위 디렉토리가 있습니다.

1 단계

이제 설정 파일을 사용하여 Oracle Database Installer를 시작하겠습니다. 다음은 첫 번째 화면입니다. 이메일 ID를 입력하고 다음 스크린 샷과 같이 확인란을 선택할 수 있습니다. 클릭Next 단추.

2 단계

다음 화면으로 이동합니다. 확인란의 선택을 취소하고Continue 계속하려면 버튼을 누르세요.

3 단계

첫 번째 옵션을 선택하십시오. Create and Configure Database 라디오 버튼을 사용하고 Next 계속하려면 버튼을 누르세요.

4 단계

학습의 기본 목적으로 Oracle을 설치하고 있으며 PC 또는 랩톱에 설치한다고 가정합니다. 따라서Desktop Class 옵션을 클릭하고 Next 계속하려면 버튼을 누르세요.

5 단계

Oracle 서버를 설치할 위치를 제공하십시오. 그냥 수정Oracle Base다른 위치는 자동으로 설정됩니다. 또한 암호를 제공해야합니다. 이것은 시스템 DBA가 사용합니다. 필요한 정보를 입력 한 후Next 계속하려면 버튼을 누르세요.

6 단계

다시 한 번 Next 계속하려면 버튼을 누르세요.

7 단계

클릭 Finish계속하려면 버튼; 그러면 실제 서버 설치가 시작됩니다.

8 단계

Oracle이 필요한 구성을 수행하기 시작할 때까지 몇 분 정도 걸립니다.

9 단계

여기에서 Oracle 설치는 필요한 구성 파일을 복사합니다. 잠시만 기다려주세요.

10 단계

데이터베이스 파일이 복사되면 다음 대화 상자가 나타납니다. 클릭하십시오OK 버튼을 누르고 나오십시오.

11 단계

설치시 다음과 같은 최종 창이 나타납니다.

마지막 단계

이제 설치를 확인할 차례입니다. 명령 프롬프트에서 Windows를 사용하는 경우 다음 명령을 사용하십시오-

sqlplus "/ as sysdba"

PL / SQL 명령과 스크립트를 작성할 SQL 프롬프트가 있어야합니다.

텍스트 에디터

명령 프롬프트에서 큰 프로그램을 실행하면 실수로 일부 작업이 손실 될 수 있습니다. 항상 명령 파일을 사용하는 것이 좋습니다. 명령 파일을 사용하려면-

  • 다음과 같이 텍스트 편집기에 코드를 입력하십시오. Notepad, Notepad+, 또는 EditPlus

  • 파일을 .sql 홈 디렉토리의 확장자.

  • 시작 SQL*Plus command prompt PL / SQL 파일을 생성 한 디렉토리에서

  • 유형 @file_name SQL * Plus 명령 프롬프트에서 프로그램을 실행합니다.

파일을 사용하여 PL / SQL 스크립트를 실행하지 않는 경우 PL / SQL 코드를 복사하고 SQL 프롬프트를 표시하는 검은 색 창을 마우스 오른쪽 버튼으로 클릭하십시오. 사용paste명령 프롬프트에 전체 코드를 붙여 넣는 옵션. 마지막으로Enter 아직 실행되지 않은 경우 코드를 실행합니다.

이 장에서는 PL / SQL의 기본 구문에 대해 설명합니다. block-structured언어; 즉, PL / SQL 프로그램이 논리적 코드 블록으로 분할되고 작성됩니다. 각 블록은 세 개의 하위 부분으로 구성됩니다.

S. 아니 섹션 및 설명
1

Declarations

이 섹션은 키워드로 시작합니다. DECLARE. 선택적 섹션이며 프로그램에서 사용할 모든 변수, 커서, 서브 프로그램 및 기타 요소를 정의합니다.

2

Executable Commands

이 섹션은 키워드로 묶여 있습니다. BEGINEND필수 섹션입니다. 프로그램의 실행 가능한 PL / SQL 문으로 구성됩니다. 최소한 하나의 실행 가능한 코드 줄이 있어야합니다.NULL command 실행되지 않아야 함을 나타냅니다.

Exception Handling

이 섹션은 키워드로 시작합니다. EXCEPTION. 이 선택적 섹션에는exception(s) 프로그램의 오류를 처리합니다.

모든 PL / SQL 문은 세미콜론 (;)으로 끝납니다. PL / SQL 블록은 다음을 사용하여 다른 PL / SQL 블록 내에 중첩 될 수 있습니다.BEGINEND. 다음은 PL / SQL 블록의 기본 구조입니다.

DECLARE 
   <declarations section> 
BEGIN 
   <executable command(s)>
EXCEPTION 
   <exception handling> 
END;

'Hello World'예제

DECLARE 
   message  varchar2(20):= 'Hello, World!'; 
BEGIN 
   dbms_output.put_line(message); 
END; 
/

그만큼 end;라인은 PL / SQL 블록의 끝을 알립니다. SQL 명령 줄에서 코드를 실행하려면 코드의 마지막 줄 뒤 첫 번째 빈 줄의 시작 부분에 /를 입력해야 할 수 있습니다. 위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Hello World  

PL/SQL procedure successfully completed.

PL / SQL 식별자

PL / SQL 식별자는 상수, 변수, 예외, 프로 시저, 커서 및 예약어입니다. 식별자는 문자 뒤에 선택적으로 추가 문자, 숫자, 달러 기호, 밑줄 및 숫자 기호로 구성되며 30자를 초과 할 수 없습니다.

기본적으로, identifiers are not case-sensitive. 그래서 당신은 사용할 수 있습니다integer 또는 INTEGER숫자 값을 나타냅니다. 예약 된 키워드는 식별자로 사용할 수 없습니다.

PL / SQL 구분 기호

구분 기호는 특별한 의미를 가진 기호입니다. 다음은 PL / SQL의 구분자 목록입니다.

구분자 기술
+, -, *, / 더하기, 빼기 / 부정, 곱하기, 나누기
% 속성 표시기
' 문자열 구분 기호
. 구성 요소 선택기
(,) 표현식 또는 목록 구분 기호
: 호스트 변수 표시기
, 항목 구분자
" 따옴표 붙은 식별자 구분 기호
= 관계 연산자
@ 원격 액세스 표시기
; 문 종결 자
:= 할당 연산자
=> 연관 연산자
|| 연결 연산자
** 지수 연산자
<<, >> 레이블 구분 기호 (시작 및 끝)
/*, */ 여러 줄 주석 구분 기호 (시작 및 끝)
-- 한 줄 주석 표시기
.. 범위 연산자
<, >, <=, >= 관계 연산자
<>, '=, ~=, ^= NOT EQUAL의 다른 버전

PL / SQL 주석

프로그램 주석은 작성하는 PL / SQL 코드에 포함될 수있는 설명문이며 소스 코드를 읽는 모든 사람을 돕습니다. 모든 프로그래밍 언어는 어떤 형태의 주석을 허용합니다.

PL / SQL은 한 줄 및 여러 줄 주석을 지원합니다. 주석에서 사용할 수있는 모든 문자는 PL / SQL 컴파일러에서 무시됩니다. PL / SQL 한 줄 주석은 구분 기호 (이중 하이픈)로 시작하고 여러 줄 주석은 / * 및 * /로 묶습니다.

DECLARE 
   -- variable declaration 
   message  varchar2(20):= 'Hello, World!'; 
BEGIN 
   /* 
   *  PL/SQL executable statement(s) 
   */ 
   dbms_output.put_line(message); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Hello World

PL/SQL procedure successfully completed.

PL / SQL 프로그램 단위

PL / SQL 단위는 다음 중 하나입니다.

  • PL / SQL 블록
  • Function
  • Package
  • 패키지 본체
  • Procedure
  • Trigger
  • Type
  • 유형 본문

이러한 각 단위는 다음 장에서 설명합니다.

이 장에서는 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 진수 (약 38 자리 10 진수) 인 ANSI 특정 부동 소수점 유형

10

FLOAT

최대 정밀도가 126 2 진 숫자 인 ANSI 및 IBM 특정 부동 소수점 유형 (약 10 진수 38 개)

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

이 장에서는 Pl / SQL의 변수에 대해 설명합니다. 변수는 프로그램이 조작 할 수있는 저장 영역에 주어진 이름 일뿐입니다. PL / SQL의 각 변수에는 변수 메모리의 크기와 레이아웃을 결정하는 특정 데이터 유형이 있습니다. 해당 메모리 내에 저장할 수있는 값의 범위와 변수에 적용 할 수있는 연산 집합입니다.

PL / SQL 변수의 이름은 선택적으로 뒤에 추가 문자, 숫자, 달러 기호, 밑줄 및 숫자 기호가 오는 문자로 구성되며 30자를 초과 할 수 없습니다. 기본적으로 변수 이름은 대소 문자를 구분하지 않습니다. 예약 된 PL / SQL 키워드를 변수 이름으로 사용할 수 없습니다.

PL / SQL 프로그래밍 언어를 사용하면 다음 장에서 다룰 날짜 시간 데이터 유형, 레코드, 컬렉션 등과 같은 다양한 유형의 변수를 정의 할 수 있습니다. 이 장에서는 기본 변수 유형 만 살펴 보겠습니다.

PL / SQL의 변수 선언

PL / SQL 변수는 선언 섹션 또는 패키지에서 전역 변수로 선언되어야합니다. 변수를 선언 할 때 PL / SQL은 변수 값에 대한 메모리를 할당하고 저장 위치는 변수 이름으로 식별됩니다.

변수를 선언하는 구문은 다음과 같습니다.

variable_name [CONSTANT] datatype [NOT NULL] [:= | DEFAULT initial_value]

여기서 variable_name 은 PL / SQL에서 유효한 식별자이고 데이터 유형 은 유효한 PL / SQL 데이터 유형이거나 지난 장에서 이미 논의한 사용자 정의 데이터 유형 이어야합니다. 정의와 함께 유효한 변수 선언은 다음과 같습니다.

sales number(10, 2); 
pi CONSTANT double precision := 3.1415; 
name varchar2(25); 
address varchar2(100);

데이터 유형에 크기, 스케일 또는 정밀도 제한을 제공하면이를 constrained declaration. 제약 된 선언은 제약없는 선언보다 적은 메모리를 필요로합니다. 예를 들면-

sales number(10, 2); 
name varchar2(25); 
address varchar2(100);

PL / SQL에서 변수 초기화

변수를 선언 할 때마다 PL / SQL은 기본값 인 NULL을 할당합니다. NULL 값이 아닌 값으로 변수를 초기화하려면 다음 중 하나를 사용하여 선언하는 동안 그렇게 할 수 있습니다.

  • 그만큼 DEFAULT 예어

  • 그만큼 assignment 운영자

예를 들면-

counter binary_integer := 0; 
greetings varchar2(20) DEFAULT 'Have a Good Day';

변수에 NULL 값을 사용하여 NOT NULL강제. NOT NULL 제약 조건을 사용하는 경우 해당 변수에 대한 초기 값을 명시 적으로 할당해야합니다.

변수를 적절하게 초기화하는 것이 좋은 프로그래밍 관행입니다. 그렇지 않으면 프로그램이 예기치 않은 결과를 생성 할 수 있습니다. 다양한 유형의 변수를 사용하는 다음 예제를 시도하십시오.

DECLARE 
   a integer := 10; 
   b integer := 20; 
   c integer; 
   f real; 
BEGIN 
   c := a + b; 
   dbms_output.put_line('Value of c: ' || c); 
   f := 70.0/3.0; 
   dbms_output.put_line('Value of f: ' || f); 
END; 
/

위의 코드가 실행되면 다음과 같은 결과가 생성됩니다.

Value of c: 30 
Value of f: 23.333333333333333333  

PL/SQL procedure successfully completed.

PL / SQL의 가변 범위

PL / SQL은 블록의 중첩을 허용합니다. 즉, 각 프로그램 블록에는 다른 내부 블록이 포함될 수 있습니다. 변수가 내부 블록 내에서 선언되면 외부 블록에 액세스 할 수 없습니다. 그러나 변수가 선언되어 외부 블록에 액세스 할 수있는 경우 모든 중첩 내부 블록에도 액세스 할 수 있습니다. 변수 범위에는 두 가지 유형이 있습니다.

  • Local variables − 내부 블록에서 선언되고 외부 블록에 접근 할 수없는 변수.

  • Global variables − 가장 바깥 쪽 블록 또는 패키지에 선언 된 변수.

다음 예는 LocalGlobal 간단한 형태의 변수-

DECLARE 
   -- Global variables  
   num1 number := 95;  
   num2 number := 85;  
BEGIN  
   dbms_output.put_line('Outer Variable num1: ' || num1); 
   dbms_output.put_line('Outer Variable num2: ' || num2); 
   DECLARE  
      -- Local variables 
      num1 number := 195;  
      num2 number := 185;  
   BEGIN  
      dbms_output.put_line('Inner Variable num1: ' || num1); 
      dbms_output.put_line('Inner Variable num2: ' || num2); 
   END;  
END; 
/

위의 코드가 실행되면 다음과 같은 결과가 생성됩니다.

Outer Variable num1: 95 
Outer Variable num2: 85 
Inner Variable num1: 195 
Inner Variable num2: 185  

PL/SQL procedure successfully completed.

PL / SQL 변수에 SQL 질의 결과 할당

사용할 수 있습니다 SELECT INTOPL / SQL 변수에 값을 할당하기위한 SQL 문. 의 각 항목에 대해SELECT list에 해당하는 유형 호환 변수가 있어야합니다. INTO list. 다음 예는 개념을 보여줍니다. CUSTOMERS라는 이름의 테이블을 만들어 보겠습니다.

(For SQL statements, please refer to the SQL tutorial)

CREATE TABLE CUSTOMERS( 
   ID   INT NOT NULL, 
   NAME VARCHAR (20) NOT NULL, 
   AGE INT NOT NULL, 
   ADDRESS CHAR (25), 
   SALARY   DECIMAL (18, 2),        
   PRIMARY KEY (ID) 
);  

Table Created

이제 테이블에 몇 가지 값을 삽입 해 보겠습니다.

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (3, 'kaushik', 23, 'Kota', 2000.00 );
  
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 ); 
 
INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 );  

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (6, 'Komal', 22, 'MP', 4500.00 );

다음 프로그램은 위 표의 값을 PL / SQL 변수에 할당합니다. SELECT INTO clause SQL-

DECLARE 
   c_id customers.id%type := 1; 
   c_name  customers.name%type; 
   c_addr customers.address%type; 
   c_sal  customers.salary%type; 
BEGIN 
   SELECT name, address, salary INTO c_name, c_addr, c_sal 
   FROM customers 
   WHERE id = c_id;  
   dbms_output.put_line 
   ('Customer ' ||c_name || ' from ' || c_addr || ' earns ' || c_sal); 
END; 
/

위의 코드가 실행되면 다음과 같은 결과가 생성됩니다.

Customer Ramesh from Ahmedabad earns 2000  

PL/SQL procedure completed successfully

이 장에서는 constantsliteralsPL / SQL에서. 상수는 일단 선언되고 프로그램에서 변경되지 않는 값을 보유합니다. 상수 선언은 이름, 데이터 유형 및 값을 지정하고 이에 대한 스토리지를 할당합니다. 선언은 또한NOT NULL constraint.

상수 선언

상수는 CONSTANT예어. 초기 값이 필요하며 해당 값을 변경할 수 없습니다. 예를 들면-

PI CONSTANT NUMBER := 3.141592654; 
DECLARE 
   -- constant declaration 
   pi constant number := 3.141592654; 
   -- other declarations 
   radius number(5,2);  
   dia number(5,2);  
   circumference number(7, 2); 
   area number (10, 2); 
BEGIN  
   -- processing 
   radius := 9.5;  
   dia := radius * 2;  
   circumference := 2.0 * pi * radius; 
   area := pi * radius * radius; 
   -- output 
   dbms_output.put_line('Radius: ' || radius); 
   dbms_output.put_line('Diameter: ' || dia); 
   dbms_output.put_line('Circumference: ' || circumference); 
   dbms_output.put_line('Area: ' || area); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Radius: 9.5 
Diameter: 19 
Circumference: 59.69 
Area: 283.53  

Pl/SQL procedure successfully completed.

PL / SQL 리터럴

리터럴은 식별자로 표시되지 않는 명시적인 숫자, 문자, 문자열 또는 부울 값입니다. 예를 들어 TRUE, 786, NULL, 'tutorialspoint'는 모두 부울, 숫자 또는 문자열 유형의 리터럴입니다. PL / SQL, 리터럴은 대소 문자를 구분합니다. PL / SQL은 다음과 같은 종류의 리터럴을 지원합니다.

  • 숫자 리터럴
  • 문자 리터럴
  • 문자열 리터럴
  • BOOLEAN 리터럴
  • 날짜 및 시간 리터럴

다음 표는 이러한 모든 범주의 리터럴 값의 예를 제공합니다.

S. 아니 리터럴 유형 및 예
1

Numeric Literals

050 78 -140 +32767

6.6667 0.0 -12.0 3.14159 +7800.00

6E5 1.0E-8 3.14159e0 -1E38 -9.5e-3

2

Character Literals

'A' '%' '9' '' 'z' '('

String Literals

'안녕하세요, 세상!'

'튜토리얼 포인트'

'19 -11 월 -12 '

4

BOOLEAN Literals

TRUE, FALSE 및 NULL.

5

Date and Time Literals

날짜 '1978-12-25';

타임 스탬프 '2012-10-29 12:01:01';

문자열 리터럴 내에 작은 따옴표를 포함하려면 다음 프로그램과 같이 두 개의 작은 따옴표를 나란히 배치하십시오.

DECLARE 
   message  varchar2(30):= 'That''s tutorialspoint.com!'; 
BEGIN 
   dbms_output.put_line(message); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

That's tutorialspoint.com!  

PL/SQL procedure successfully completed.

이 장에서는 PL / SQL의 연산자에 대해 설명합니다. 연산자는 컴파일러에게 특정 수학적 또는 논리적 조작을 수행하도록 지시하는 기호입니다. PL / SQL 언어는 내장 연산자가 풍부하며 다음 유형의 연산자를 제공합니다.

  • 산술 연산자
  • 관계 연산자
  • 비교 연산자
  • 논리 연산자
  • 문자열 연산자

여기서는 산술, 관계형, 비교 및 ​​논리 연산자를 하나씩 이해합니다. 문자열 연산자는 이후 장에서 설명합니다.PL/SQL - Strings.

산술 연산자

다음 표는 PL / SQL에서 지원하는 모든 산술 연산자를 보여줍니다. 가정하자variable A 10 개를 보유하고 variable B 5 개를 보유하면-

예시보기

운영자 기술
+ 두 개의 피연산자를 더합니다. A + B는 15를 줄 것입니다
- 첫 번째에서 두 번째 피연산자를 뺍니다. A-B는 5를 줄 것입니다
* 두 피연산자를 곱합니다. A * B는 50을 줄 것입니다
/ 분자를 탈 분자로 나눕니다. A / B는 2를 줄 것입니다
** 지수 연산자, 한 피연산자를 다른 피연산자로 올립니다. A ** B는 100000을 줄 것입니다

관계 연산자

관계 연산자는 두 표현식 또는 값을 비교하고 부울 결과를 반환합니다. 다음 표는 PL / SQL에서 지원하는 모든 관계 연산자를 보여줍니다. 가정하자variable A 10 개를 보유하고 variable B 20 개를 보유하면-

예시보기

운영자 기술
= 두 피연산자의 값이 같은지 확인하고, 예이면 조건이 참이됩니다. (A = B)는 사실이 아닙니다.

! =

<>

~ =

두 피연산자의 값이 같은지 확인하고, 값이 같지 않으면 조건이 참이됩니다. (A! = B)는 사실입니다.
> 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 큰지 확인하고, 그렇다면 조건이 참이됩니다. (A> B)는 사실이 아닙니다.
< 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작은 지 확인하고, 그렇다면 조건이 참이됩니다. (A <B)는 사실입니다.
> = 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 크거나 같은지 확인하고, 그렇다면 조건이 참이됩니다. (A> = B)는 사실이 아닙니다.
<= 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작거나 같은지 확인하고, 그렇다면 조건이 참이됩니다. (A <= B) 참

비교 연산자

비교 연산자는 한 표현식을 다른 표현식과 비교하는 데 사용됩니다. 결과는 항상TRUE, FALSE 또는 NULL.

예시보기

운영자 기술
처럼 LIKE 연산자는 문자, 문자열 또는 CLOB 값을 패턴과 비교하고 값이 패턴과 일치하면 TRUE를, 일치하지 않으면 FALSE를 반환합니다. 'Z % A_i'와 같은 'Zara Ali'는 Boolean true를 반환하는 반면 'Z % A_i'와 같은 'Nuha Ali'는 Boolean false를 반환합니다.
중에서 BETWEEN 연산자는 값이 지정된 범위에 있는지 여부를 테스트합니다. x BETWEEN a와 b는 x> = a와 x <= b를 의미합니다. x = 10이면 5와 20 사이의 x는 true를 반환하고 5와 10 사이의 x는 true를 반환하지만 11과 20 사이의 x는 false를 반환합니다.
IN 연산자 테스트는 멤버 자격을 설정합니다. x IN (세트)은 x가 세트의 모든 구성원과 동일 함을 의미합니다. x = 'm'이면 x in ( 'a', 'b', 'c')는 Boolean false를 반환하지만 x in ( 'm', 'n', 'o')는 Boolean true를 반환합니다.
NULL입니다. IS NULL 연산자는 피연산자가 NULL이면 BOOLEAN 값 TRUE를 반환하고 NULL이 아니면 FALSE를 반환합니다. NULL 값을 포함하는 비교는 항상 NULL을 생성합니다. x = 'm'이면 'x is null'은 Boolean false를 반환합니다.

논리 연산자

다음 표는 PL / SQL에서 지원하는 논리 연산자를 보여줍니다. 이러한 모든 연산자는 부울 피연산자에 대해 작동하고 부울 결과를 생성합니다. 가정하자variable A 사실을 유지하고 variable B 거짓을 유지하면-

예시보기

운영자 기술
논리 AND 연산자라고합니다. 두 피연산자가 모두 참이면 조건이 참이됩니다. (A와 B)는 거짓입니다.
또는 논리 OR 연산자라고합니다. 두 피연산자 중 하나가 참이면 조건이 참이됩니다. (A 또는 B)가 참입니다.
아니 논리 NOT 연산자라고합니다. 피연산자의 논리적 상태를 반전하는 데 사용됩니다. 조건이 참이면 논리 NOT 연산자는이를 거짓으로 만듭니다. 아니 (A와 B)는 사실입니다.

PL / SQL 연산자 우선 순위

연산자 우선 순위는 식의 용어 그룹화를 결정합니다. 이는식이 평가되는 방식에 영향을줍니다. 특정 연산자는 다른 연산자보다 우선 순위가 높습니다. 예를 들어 곱셈 연산자는 더하기 연산자보다 우선 순위가 높습니다.

예를 들면 x = 7 + 3 * 2; 여기,x 할당 13, 연산자 *가 +보다 우선 순위가 높기 때문에 20이 아니므로 먼저 곱해집니다. 3*2 그런 다음 7.

여기에서 우선 순위가 가장 높은 연산자는 테이블 맨 위에 표시되고 가장 낮은 연산자는 맨 아래에 표시됩니다. 식 내에서 우선 순위가 높은 연산자가 먼저 평가됩니다.

연산자의 우선 순위는 =, <,>, <=,> =, <>,! =, ~ =, ^ =, IS NULL, LIKE, BETWEEN, IN입니다.

예시보기

운영자 조작
** 지수화
+,- 정체성, 부정
*, / 곱셈, 나눗셈
+,-, || 더하기, 빼기, 연결
비교
아니 논리적 부정
접속사
또는 포함

이 장에서는 PL / SQL의 조건에 대해 설명합니다. 의사 결정 구조는 프로그래머가 조건이 참인 경우 실행될 명령문 또는 명령문과 함께 프로그램에서 평가하거나 테스트 할 하나 이상의 조건을 지정하고 선택적으로 조건은 거짓으로 결정됩니다.

다음은 대부분의 프로그래밍 언어에서 발견되는 일반적인 조건부 (즉, 의사 결정) 구조의 일반적인 형태입니다.

PL / SQL 프로그래밍 언어는 다음 유형의 의사 결정 문을 제공합니다. 세부 사항을 확인하려면 다음 링크를 클릭하십시오.

S. 아니 성명 및 설명
1 IF-THEN 문

그만큼 IF statement 조건을 키워드로 묶인 일련의 명령문과 연관시킵니다. THENEND IF. 조건이 참이면 명령문이 실행되고 조건이 거짓 또는 NULL이면 IF 문은 아무 작업도 수행하지 않습니다.

2 IF-THEN-ELSE 문

IF statement 키워드를 추가 ELSE대체 문장 순서가 뒤 따릅니다. 조건이 false 또는 NULL이면 대체 명령문 시퀀스 만 실행됩니다. 명령문 시퀀스 중 하나가 실행되도록합니다.

IF-THEN-ELSIF 문

여러 대안 중에서 선택할 수 있습니다.

4 사례 진술

IF 문과 마찬가지로 CASE statement 실행할 명령문 시퀀스 하나를 선택합니다.

그러나 시퀀스를 선택하기 위해 CASE 문은 여러 부울식이 아닌 선택기를 사용합니다. 선택기는 여러 대안 중 하나를 선택하는 데 사용되는 값을 갖는 표현식입니다.

5 검색된 CASE 문

검색된 CASE 문 has no selector, WHEN 절에는 부울 값을 생성하는 검색 조건이 포함되어 있습니다.

6 중첩 된 IF-THEN-ELSE

하나를 사용할 수 있습니다 IF-THEN 또는 IF-THEN-ELSIF 다른 내부의 진술 IF-THEN 또는 IF-THEN-ELSIF 진술 (들).

이 장에서는 PL / SQL의 루프에 대해 설명합니다. 코드 블록을 여러 번 실행해야하는 상황이있을 수 있습니다. 일반적으로 명령문은 순차적으로 실행됩니다. 함수의 첫 번째 명령문이 먼저 실행되고 두 번째 명령문이 실행되는 식입니다.

프로그래밍 언어는보다 복잡한 실행 경로를 허용하는 다양한 제어 구조를 제공합니다.

루프 문을 사용하면 문 또는 문 그룹을 여러 번 실행할 수 있으며 다음은 대부분의 프로그래밍 언어에서 루프 문의 일반적인 형식입니다.

PL / SQL은 루핑 요구 사항을 처리하기 위해 다음 유형의 루프를 제공합니다. 세부 사항을 확인하려면 다음 링크를 클릭하십시오.

S. 아니 루프 유형 및 설명
1 PL / SQL 기본 루프

이 루프 구조에서 명령문 시퀀스는 LOOP 및 END LOOP 문 사이에 포함됩니다. 반복 할 때마다 일련의 명령문이 실행 된 다음 루프의 맨 위에서 제어가 다시 시작됩니다.

2 루프 동안 PL / SQL

주어진 조건이 참인 동안 명령문 또는 명령문 그룹을 반복합니다. 루프 본문을 실행하기 전에 조건을 테스트합니다.

PL / SQL FOR LOOP

일련의 문을 여러 번 실행하고 루프 변수를 관리하는 코드를 축약합니다.

4 PL / SQL의 중첩 루프

다른 기본 루프, while 또는 for 루프 내에서 하나 이상의 루프를 사용할 수 있습니다.

PL / SQL 루프 레이블 지정

PL / SQL 루프에 레이블을 지정할 수 있습니다. 레이블은 이중 꺾쇠 괄호 (<< 및 >>)로 묶어야하며 LOOP 문의 시작 부분에 나타나야합니다. 레이블 이름은 LOOP 문 끝에 나타날 수도 있습니다. EXIT 문의 레이블을 사용하여 루프를 종료 할 수 있습니다.

다음 프로그램은 개념을 설명합니다-

DECLARE 
   i number(1); 
   j number(1); 
BEGIN 
   << outer_loop >> 
   FOR i IN 1..3 LOOP 
      << inner_loop >> 
      FOR j IN 1..3 LOOP 
         dbms_output.put_line('i is: '|| i || ' and j is: ' || j); 
      END loop inner_loop; 
   END loop outer_loop; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

i is: 1 and j is: 1 
i is: 1 and j is: 2 
i is: 1 and j is: 3 
i is: 2 and j is: 1 
i is: 2 and j is: 2 
i is: 2 and j is: 3 
i is: 3 and j is: 1 
i is: 3 and j is: 2 
i is: 3 and j is: 3  

PL/SQL procedure successfully completed.

루프 제어문

루프 제어문은 정상적인 순서에서 실행을 변경합니다. 실행이 범위를 벗어나면 해당 범위에서 생성 된 모든 자동 개체가 삭제됩니다.

PL / SQL은 다음 제어문을 지원합니다. 레이블링 루프는 루프 외부에서 컨트롤을 가져 오는데도 도움이됩니다. 자세한 내용을 확인하려면 다음 링크를 클릭하십시오.

S. 아니 제어문 및 설명
1 EXIT 문

Exit 문은 루프를 완료하고 제어는 END LOOP 직후 문으로 전달됩니다.

2 CONTINUE 문

루프가 본문의 나머지 부분을 건너 뛰고 반복하기 전에 즉시 상태를 다시 테스트하도록합니다.

GOTO 문

레이블이 지정된 명령문으로 제어를 전송합니다. 프로그램에서 GOTO 문을 사용하는 것은 권장되지 않습니다.

PL / SQL의 문자열은 실제로 선택적 크기 사양이있는 일련의 문자입니다. 문자는 숫자, 문자, 공백, 특수 문자 또는 모두의 조합 일 수 있습니다. PL / SQL은 세 종류의 문자열을 제공합니다.

  • Fixed-length strings− 이러한 문자열에서 프로그래머는 문자열을 선언하는 동안 길이를 지정합니다. 문자열은 지정된 길이만큼 공백으로 오른쪽으로 채워집니다.

  • Variable-length strings − 이러한 문자열에서 문자열의 최대 길이는 32,767이며 패딩이 발생하지 않습니다.

  • Character large objects (CLOBs) − 최대 128 테라 바이트가 될 수있는 가변 길이 문자열입니다.

PL / SQL 문자열은 변수 또는 리터럴 일 수 있습니다. 문자열 리터럴은 따옴표로 묶습니다. 예를 들면

'This is a string literal.' Or 'hello world'

문자열 리터럴 내에 작은 따옴표를 포함하려면 두 개의 작은 따옴표를 나란히 입력해야합니다. 예를 들면

'this isn''t what it looks like'

문자열 변수 선언

Oracle 데이터베이스는 CHAR, NCHAR, VARCHAR2, NVARCHAR2, CLOB 및 NCLOB와 같은 다양한 문자열 데이터 유형을 제공합니다. 접두사가 붙은 데이터 유형'N' 아르 'national character set' 유니 코드 문자 데이터를 저장하는 데이터 유형.

가변 길이 문자열을 선언해야하는 경우 해당 문자열의 최대 길이를 제공해야합니다. 예를 들어, VARCHAR2 데이터 유형입니다. 다음 예제는 일부 문자열 변수를 선언하고 사용하는 방법을 보여줍니다.

DECLARE 
   name varchar2(20); 
   company varchar2(30); 
   introduction clob; 
   choice char(1); 
BEGIN 
   name := 'John Smith'; 
   company := 'Infotech'; 
   introduction := ' Hello! I''m John Smith from Infotech.'; 
   choice := 'y'; 
   IF choice = 'y' THEN 
      dbms_output.put_line(name); 
      dbms_output.put_line(company); 
      dbms_output.put_line(introduction); 
   END IF; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

John Smith 
Infotech
Hello! I'm John Smith from Infotech.  

PL/SQL procedure successfully completed

고정 길이 문자열을 선언하려면 CHAR 데이터 유형을 사용하십시오. 여기에서는 고정 길이 변수의 최대 길이를 지정할 필요가 없습니다. 길이 제한을 해제하면 Oracle 데이터베이스는 자동으로 필요한 최대 길이를 사용합니다. 다음 두 선언은 동일합니다-

red_flag CHAR(1) := 'Y'; 
 red_flag CHAR   := 'Y';

PL / SQL 문자열 함수 및 연산자

PL / SQL은 연결 연산자를 제공합니다. (||)두 개의 문자열을 결합합니다. 다음 표는 PL / SQL에서 제공하는 문자열 함수를 제공합니다.

S. 아니 기능 및 목적
1

ASCII(x);

문자 x의 ASCII 값을 반환합니다.

2

CHR(x);

ASCII 값이 x 인 문자를 반환합니다.

CONCAT(x, y);

문자열 x와 y를 연결하고 추가 된 문자열을 반환합니다.

4

INITCAP(x);

x에있는 각 단어의 첫 글자를 대문자로 변환하고 해당 문자열을 반환합니다.

5

INSTR(x, find_string [, start] [, occurrence]);

검색 find_string x에서 발생하는 위치를 반환합니다.

6

INSTRB(x);

다른 문자열 내의 문자열 위치를 반환하지만 값은 바이트 단위로 반환합니다.

7

LENGTH(x);

x의 문자 수를 반환합니다.

8

LENGTHB(x);

1 바이트 문자 집합에 대한 문자열 길이를 바이트 단위로 반환합니다.

9

LOWER(x);

x의 문자를 소문자로 변환하고 해당 문자열을 반환합니다.

10

LPAD(x, width [, pad_string]) ;

패드 x 왼쪽에 공백을 사용하여 문자열의 전체 길이를 최대 너비 문자까지 가져옵니다.

11

LTRIM(x [, trim_string]);

왼쪽에서 문자를 자릅니다. x.

12

NANVL(x, value);

x가 NaN 특수 값 (숫자가 아님)과 일치하면 값을 반환하고, 그렇지 않으면 값을 반환합니다. x 반환됩니다.

13

NLS_INITCAP(x);

NLSSORT에서 지정한대로 다른 정렬 방법을 사용할 수 있다는 점을 제외하면 INITCAP 함수와 동일합니다.

14

NLS_LOWER(x) ;

NLSSORT에서 지정한대로 다른 정렬 방법을 사용할 수 있다는 점을 제외하면 LOWER 함수와 동일합니다.

15

NLS_UPPER(x);

NLSSORT에서 지정한대로 다른 정렬 방법을 사용할 수 있다는 점을 제외하면 UPPER 함수와 동일합니다.

16

NLSSORT(x);

문자 정렬 방법을 변경합니다. NLS 함수 앞에 지정해야합니다. 그렇지 않으면 기본 정렬이 사용됩니다.

17

NVL(x, value);

값을 반환하는 경우 xnull입니다. 그렇지 않으면 x가 반환됩니다.

18

NVL2(x, value1, value2);

x가 null이 아니면 value1을 반환합니다. x가 null이면 value2가 반환됩니다.

19

REPLACE(x, search_string, replace_string);

검색 x search_string의 경우이를 replace_string으로 바꿉니다.

20

RPAD(x, width [, pad_string]);

패드 x 오른쪽으로.

21

RTRIM(x [, trim_string]);

트림 x 오른쪽에서.

22

SOUNDEX(x) ;

다음의 음성 표현을 포함하는 문자열을 반환합니다. x.

23

SUBSTR(x, start [, length]);

하위 문자열을 반환합니다. xstart로 지정된 위치에서 시작합니다. 하위 문자열에 대한 선택적 길이를 제공 할 수 있습니다.

24

SUBSTRB(x);

1 바이트 문자 시스템의 경우 매개 변수가 문자 대신 바이트로 표현된다는 점을 제외하면 SUBSTR과 동일합니다.

25

TRIM([trim_char FROM) x);

왼쪽과 오른쪽에서 문자를 자릅니다. x.

26

UPPER(x);

x의 문자를 대문자로 변환하고 해당 문자열을 반환합니다.

이제 개념을 이해하기 위해 몇 가지 예를 살펴 보겠습니다.

예 1

DECLARE 
   greetings varchar2(11) := 'hello world'; 
BEGIN 
   dbms_output.put_line(UPPER(greetings)); 
    
   dbms_output.put_line(LOWER(greetings)); 
    
   dbms_output.put_line(INITCAP(greetings)); 
    
   /* retrieve the first character in the string */ 
   dbms_output.put_line ( SUBSTR (greetings, 1, 1)); 
    
   /* retrieve the last character in the string */ 
   dbms_output.put_line ( SUBSTR (greetings, -1, 1)); 
    
   /* retrieve five characters,  
      starting from the seventh position. */ 
   dbms_output.put_line ( SUBSTR (greetings, 7, 5)); 
    
   /* retrieve the remainder of the string, 
      starting from the second position. */ 
   dbms_output.put_line ( SUBSTR (greetings, 2)); 
     
   /* find the location of the first "e" */ 
   dbms_output.put_line ( INSTR (greetings, 'e')); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

HELLO WORLD 
hello world 
Hello World 
h 
d 
World 
ello World 
2  

PL/SQL procedure successfully completed.

예 2

DECLARE 
   greetings varchar2(30) := '......Hello World.....'; 
BEGIN 
   dbms_output.put_line(RTRIM(greetings,'.')); 
   dbms_output.put_line(LTRIM(greetings, '.')); 
   dbms_output.put_line(TRIM( '.' from greetings)); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

......Hello World  
Hello World..... 
Hello World  

PL/SQL procedure successfully completed.

이 장에서는 PL / SQL의 어레이에 대해 설명합니다. PL / SQL 프로그래밍 언어는 다음과 같은 데이터 구조를 제공합니다.VARRAY, 동일한 유형의 요소의 고정 크기 순차 컬렉션을 저장할 수 있습니다. 배열은 정렬 된 데이터 모음을 저장하는 데 사용되지만 배열을 동일한 유형의 변수 모음으로 생각하는 것이 더 좋습니다.

모든 varray는 연속적인 메모리 위치로 구성됩니다. 가장 낮은 주소는 첫 번째 요소에 해당하고 가장 높은 주소는 마지막 요소에 해당합니다.

배열은 컬렉션 유형 데이터의 일부이며 가변 크기 배열을 나타냅니다. 이후 장에서 다른 컬렉션 유형을 연구 할 것입니다.'PL/SQL Collections'.

의 각 요소 varray연관된 색인이 있습니다. 또한 동적으로 변경할 수있는 최대 크기도 있습니다.

Varray 유형 생성

varray 유형은 CREATE TYPE성명서. varray에 저장되는 요소의 최대 크기와 유형을 지정해야합니다.

스키마 수준에서 VARRAY 유형을 생성하는 기본 구문은 다음과 같습니다.

CREATE OR REPLACE TYPE varray_type_name IS VARRAY(n) of <element_type>

어디,

  • varray_type_name 은 유효한 속성 이름입니다.
  • n 은 varray의 요소 수 (최대)입니다.
  • element_type 은 배열 요소의 데이터 유형입니다.

varray의 최대 크기는 ALTER TYPE 성명서.

예를 들면

CREATE Or REPLACE TYPE namearray AS VARRAY(3) OF VARCHAR2(10); 
/ 

Type created.

PL / SQL 블록 내에서 VARRAY 유형을 생성하는 기본 구문은 다음과 같습니다.

TYPE varray_type_name IS VARRAY(n) of <element_type>

예를 들면-

TYPE namearray IS VARRAY(5) OF VARCHAR2(10); 
Type grades IS VARRAY(5) OF INTEGER;

이제 개념을 이해하기 위해 몇 가지 예를 살펴 보겠습니다.

예 1

다음 프로그램은 varrays의 사용을 보여줍니다-

DECLARE 
   type namesarray IS VARRAY(5) OF VARCHAR2(10); 
   type grades IS VARRAY(5) OF INTEGER; 
   names namesarray; 
   marks grades; 
   total integer; 
BEGIN 
   names := namesarray('Kavita', 'Pritam', 'Ayan', 'Rishav', 'Aziz'); 
   marks:= grades(98, 97, 78, 87, 92); 
   total := names.count; 
   dbms_output.put_line('Total '|| total || ' Students'); 
   FOR i in 1 .. total LOOP 
      dbms_output.put_line('Student: ' || names(i) || ' 
      Marks: ' || marks(i)); 
   END LOOP; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Total 5 Students 
Student: Kavita  Marks: 98 
Student: Pritam  Marks: 97 
Student: Ayan  Marks: 78 
Student: Rishav  Marks: 87 
Student: Aziz  Marks: 92 

PL/SQL procedure successfully completed.

Please note

  • Oracle 환경에서 varray의 시작 색인은 항상 1입니다.

  • varray와 동일한 이름을 가진 varray 유형의 생성자 메서드를 사용하여 varray 요소를 초기화 할 수 있습니다.

  • Varray는 1 차원 배열입니다.

  • varray는 선언 될 때 자동으로 NULL이며 해당 요소를 참조하기 전에 초기화해야합니다.

예 2

varray의 요소는 데이터베이스 테이블의 % ROWTYPE 또는 데이터베이스 테이블 필드의 % TYPE 일 수도 있습니다. 다음 예는 개념을 보여줍니다.

데이터베이스에 저장된 CUSTOMERS 테이블을 다음과 같이 사용합니다.

Select * from customers;  

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+

다음 예제는 cursor, 별도의 장에서 자세히 공부할 것입니다.

DECLARE 
   CURSOR c_customers is 
   SELECT  name FROM customers; 
   type c_list is varray (6) of customers.name%type; 
   name_list c_list := c_list(); 
   counter integer :=0; 
BEGIN 
   FOR n IN c_customers LOOP 
      counter := counter + 1; 
      name_list.extend; 
      name_list(counter)  := n.name; 
      dbms_output.put_line('Customer('||counter ||'):'||name_list(counter)); 
   END LOOP; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Customer(1): Ramesh  
Customer(2): Khilan  
Customer(3): kaushik     
Customer(4): Chaitali  
Customer(5): Hardik  
Customer(6): Komal  

PL/SQL procedure successfully completed.

이 장에서는 PL / SQL의 프로 시저에 대해 설명합니다. ㅏsubprogram특정 작업을 수행하는 프로그램 단위 / 모듈입니다. 이러한 하위 프로그램은 결합되어 더 큰 프로그램을 형성합니다. 이를 기본적으로 '모듈 형 설계'라고합니다. 서브 프로그램은 다른 서브 프로그램이나calling program.

서브 프로그램을 만들 수 있습니다-

  • 스키마 수준에서
  • 패키지 내부
  • PL / SQL 블록 내부

스키마 수준에서 하위 프로그램은 standalone subprogram. CREATE PROCEDURE 또는 CREATE FUNCTION 문으로 생성됩니다. 데이터베이스에 저장되며 DROP PROCEDURE 또는 DROP FUNCTION 문으로 삭제할 수 있습니다.

패키지 내부에 생성 된 하위 프로그램은 packaged subprogram. 데이터베이스에 저장되며 DROP PACKAGE 문으로 패키지를 삭제 한 경우에만 삭제할 수 있습니다. 이 장에서 패키지에 대해 논의 할 것입니다.'PL/SQL - Packages'.

PL / SQL 하위 프로그램은 일련의 매개 변수를 사용하여 호출 할 수있는 PL / SQL 블록입니다. PL / SQL은 두 종류의 서브 프로그램을 제공합니다.

  • Functions−이 서브 프로그램은 단일 값을 반환합니다. 주로 값을 계산하고 반환하는 데 사용됩니다.

  • Procedures−이 서브 프로그램은 값을 직접 반환하지 않습니다. 주로 작업을 수행하는 데 사용됩니다.

이 장에서는 PL/SQL procedure. 우리는 논의 할 것이다PL/SQL function 다음 장에서.

PL / SQL 하위 프로그램의 일부

각 PL / SQL 하위 프로그램에는 이름이 있으며 매개 변수 목록도있을 수 있습니다. 익명의 PL / SQL 블록과 마찬가지로 명명 된 블록도 다음 세 부분으로 구성됩니다.

S. 아니 부품 및 설명
1

Declarative Part

옵션 부품입니다. 그러나 서브 프로그램의 선언 부분은 DECLARE 키워드로 시작하지 않습니다. 여기에는 유형, 커서, 상수, 변수, 예외 및 중첩 된 하위 프로그램의 선언이 포함됩니다. 이러한 항목은 서브 프로그램에 국한되며 서브 프로그램이 실행을 완료하면 존재하지 않습니다.

2

Executable Part

이것은 필수 부분이며 지정된 작업을 수행하는 명령문을 포함합니다.

Exception-handling

이것은 다시 선택적인 부분입니다. 여기에는 런타임 오류를 처리하는 코드가 포함되어 있습니다.

프로 시저 생성

절차는 CREATE OR REPLACE PROCEDURE성명서. CREATE OR REPLACE PROCEDURE 문의 단순화 된 구문은 다음과 같습니다.

CREATE [OR REPLACE] PROCEDURE procedure_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
{IS | AS} 
BEGIN 
  < procedure_body > 
END procedure_name;

어디,

  • procedure-name프로 시저의 이름을 지정합니다.

  • [OR REPLACE] 옵션을 사용하면 기존 프로 시저를 수정할 수 있습니다.

  • 선택적 매개 변수 목록에는 매개 변수의 이름, 모드 및 유형이 포함됩니다. IN 외부에서 전달 될 값을 나타내고 OUT은 프로 시저 외부에서 값을 반환하는 데 사용되는 매개 변수를 나타냅니다.

  • procedure-body 는 실행 가능한 부분을 포함합니다.

  • 독립형 프로 시저를 작성하기 위해 IS 키워드 대신 AS 키워드가 사용됩니다.

다음 예제에서는 'Hello World!'문자열을 표시하는 간단한 프로 시저를 만듭니다. 실행되면 화면에.

CREATE OR REPLACE PROCEDURE greetings 
AS 
BEGIN 
   dbms_output.put_line('Hello World!'); 
END; 
/

위의 코드가 SQL 프롬프트를 사용하여 실행되면 다음 결과가 생성됩니다.

Procedure created.

독립형 절차 실행

독립형 프로시 저는 두 가지 방법으로 호출 할 수 있습니다.

  • 사용 EXECUTE 예어

  • PL / SQL 블록에서 프로 시저 이름 호출

위의 절차는 'greetings' EXECUTE 키워드를 사용하여 다음과 같이 호출 할 수 있습니다.

EXECUTE greetings;

위의 호출이 표시됩니다-

Hello World

PL/SQL procedure successfully completed.

이 절차는 다른 PL / SQL 블록에서 호출 할 수도 있습니다.

BEGIN 
   greetings; 
END; 
/

위의 호출이 표시됩니다-

Hello World  

PL/SQL procedure successfully completed.

독립형 프로 시저 삭제

독립형 프로시 저는 DROP PROCEDURE성명서. 프로 시저 삭제 구문은 다음과 같습니다.

DROP PROCEDURE procedure-name;

다음 문을 사용하여 인사말 절차를 삭제할 수 있습니다.

DROP PROCEDURE greetings;

PL / SQL 하위 프로그램의 매개 변수 모드

다음 표는 PL / SQL 서브 프로그램의 매개 변수 모드를 나열합니다.

S. 아니 매개 변수 모드 및 설명
1

IN

IN 매개 변수를 사용하면 값을 서브 프로그램에 전달할 수 있습니다. It is a read-only parameter. 서브 프로그램 내에서 IN 매개 변수는 상수처럼 작동합니다. 값을 할당 할 수 없습니다. 상수, 리터럴, 초기화 된 변수 또는 표현식을 IN 매개 변수로 전달할 수 있습니다. 기본값으로 초기화 할 수도 있습니다. 그러나이 경우 서브 프로그램 호출에서 생략됩니다.It is the default mode of parameter passing. Parameters are passed by reference.

2

OUT

OUT 매개 변수는 호출 프로그램에 값을 리턴합니다. 서브 프로그램 내에서 OUT 매개 변수는 변수처럼 작동합니다. 값을 변경하고 할당 한 후 값을 참조 할 수 있습니다.The actual parameter must be variable and it is passed by value.

IN OUT

IN OUT매개 변수는 초기 값을 서브 프로그램에 전달하고 업데이트 된 값을 호출자에게 반환합니다. 값을 할당 할 수 있으며 값을 읽을 수 있습니다.

IN OUT 형식 매개 변수에 해당하는 실제 매개 변수는 상수 또는 표현식이 아닌 변수 여야합니다. 형식 매개 변수에는 값이 지정되어야합니다.Actual parameter is passed by value.

IN & OUT 모드 예 1

이 프로그램은 최소 두 값을 찾습니다. 여기서 프로시 저는 IN 모드를 사용하여 두 개의 숫자를 취하고 OUT 매개 변수를 사용하여 최소값을 반환합니다.

DECLARE 
   a number; 
   b number; 
   c number;
PROCEDURE findMin(x IN number, y IN number, z OUT number) IS 
BEGIN 
   IF x < y THEN 
      z:= x; 
   ELSE 
      z:= y; 
   END IF; 
END;   
BEGIN 
   a:= 23; 
   b:= 45; 
   findMin(a, b, c); 
   dbms_output.put_line(' Minimum of (23, 45) : ' || c); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Minimum of (23, 45) : 23  

PL/SQL procedure successfully completed.

IN & OUT 모드 예 2

이 절차는 전달 된 값의 제곱 값을 계산합니다. 이 예제는 동일한 매개 변수를 사용하여 값을 수락 한 다음 다른 결과를 반환하는 방법을 보여줍니다.

DECLARE 
   a number; 
PROCEDURE squareNum(x IN OUT number) IS 
BEGIN 
  x := x * x; 
END;  
BEGIN 
   a:= 23; 
   squareNum(a); 
   dbms_output.put_line(' Square of (23): ' || a); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Square of (23): 529 

PL/SQL procedure successfully completed.

매개 변수 전달 방법

실제 매개 변수는 세 가지 방법으로 전달할 수 있습니다.

  • 위치 표기법
  • 명명 된 표기법
  • 혼합 표기법

위치 표기법

위치 표기법에서는 프로 시저를 다음과 같이 호출 할 수 있습니다.

findMin(a, b, c, d);

위치 표기법에서 첫 번째 실제 매개 변수는 첫 번째 형식 매개 변수로 대체됩니다. 두 번째 실제 매개 변수는 두 번째 형식 매개 변수로 대체됩니다. 그래서,a 대체된다 x, b 대체된다 y, c 대체된다 zd 대체된다 m.

명명 된 표기법

명명 된 표기법에서 실제 매개 변수는 다음을 사용하여 형식 매개 변수와 연관됩니다. arrow symbol ( => ). 절차 호출은 다음과 같습니다.

findMin(x => a, y => b, z => c, m => d);

혼합 표기법

혼합 표기법에서는 프로 시저 호출에서 두 표기법을 혼합 할 수 있습니다. 그러나 위치 표기법은 명명 된 표기법 앞에 와야합니다.

다음 전화는 합법적입니다-

findMin(a, b, c, m => d);

그러나 이것은 합법적이지 않습니다.

findMin(x => a, b, c, d);

이 장에서는 PL / SQL의 함수에 대해 설명합니다. 함수는 값을 반환한다는 점을 제외하면 프로 시저와 동일합니다. 따라서 이전 장에서 설명한 모든 내용은 함수에도 적용됩니다.

함수 생성

독립형 기능은 CREATE FUNCTION성명서. 에 대한 단순화 된 구문CREATE OR REPLACE PROCEDURE 진술은 다음과 같습니다-

CREATE [OR REPLACE] FUNCTION function_name 
[(parameter_name [IN | OUT | IN OUT] type [, ...])] 
RETURN return_datatype 
{IS | AS} 
BEGIN 
   < function_body > 
END [function_name];

어디,

  • function-name함수의 이름을 지정합니다.

  • [OR REPLACE] 옵션을 사용하면 기존 함수를 수정할 수 있습니다.

  • 선택적 매개 변수 목록에는 매개 변수의 이름, 모드 및 유형이 포함됩니다. IN은 외부에서 전달 될 값을 나타내고 OUT은 프로 시저 외부에서 값을 반환하는 데 사용되는 매개 변수를 나타냅니다.

  • 함수에는 return 성명서.

  • 반환 절은 데이터 당신이 함수에서 반환하려고하는 유형을 지정합니다.

  • function-body 는 실행 가능한 부분을 포함합니다.

  • 독립형 함수를 만들기 위해 IS 키워드 대신 AS 키워드가 사용됩니다.

다음 예제는 독립 실행 형 함수를 만들고 호출하는 방법을 보여줍니다. 이 함수는 customers 테이블의 총 CUSTOMERS 수를 반환합니다.

PL / SQL 변수 장 에서 생성 한 CUSTOMERS 테이블을 사용합니다.

Select * from customers; 
 
+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+
CREATE OR REPLACE FUNCTION totalCustomers 
RETURN number IS 
   total number(2) := 0; 
BEGIN 
   SELECT count(*) into total 
   FROM customers; 
    
   RETURN total; 
END; 
/

위의 코드가 SQL 프롬프트를 사용하여 실행되면 다음 결과가 생성됩니다.

Function created.

함수 호출

함수를 만드는 동안 함수가 수행해야하는 작업에 대한 정의를 제공합니다. 함수를 사용하려면 정의 된 작업을 수행하기 위해 해당 함수를 호출해야합니다. 프로그램이 함수를 호출하면 프로그램 제어가 호출 된 함수로 전송됩니다.

호출 된 함수는 정의 된 작업을 수행하고 return 문이 실행되거나 last end statement 도달하면 프로그램 제어를 주 프로그램으로 되돌립니다.

함수를 호출하려면 함수 이름과 함께 필수 매개 변수를 전달하기 만하면됩니다. 함수가 값을 반환하면 반환 된 값을 저장할 수 있습니다. 다음 프로그램은 함수를 호출합니다.totalCustomers 익명의 블록에서-

DECLARE 
   c number(2); 
BEGIN 
   c := totalCustomers(); 
   dbms_output.put_line('Total no. of Customers: ' || c); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Total no. of Customers: 6  

PL/SQL procedure successfully completed.

다음 예제는 최대 두 개의 값을 계산하고 반환하는 단순 PL / SQL 함수의 선언, 정의 및 호출을 보여줍니다.

DECLARE 
   a number; 
   b number; 
   c number; 
FUNCTION findMax(x IN number, y IN number)  
RETURN number 
IS 
    z number; 
BEGIN 
   IF x > y THEN 
      z:= x; 
   ELSE 
      Z:= y; 
   END IF;  
   RETURN z; 
END; 
BEGIN 
   a:= 23; 
   b:= 45;  
   c := findMax(a, b); 
   dbms_output.put_line(' Maximum of (23,45): ' || c); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Maximum of (23,45): 45   

PL/SQL procedure successfully completed.

PL / SQL 재귀 함수

우리는 프로그램이나 하위 프로그램이 다른 하위 프로그램을 호출 할 수 있음을 보았습니다. 서브 프로그램이 자신을 호출 할 때이를 재귀 호출이라고하며 프로세스는recursion.

개념을 설명하기 위해 숫자의 계승을 계산해 보겠습니다. n의 계승은 다음과 같이 정의됩니다.

n! = n*(n-1)! 
   = n*(n-1)*(n-2)! 
      ... 
   = n*(n-1)*(n-2)*(n-3)... 1

다음 프로그램은 자신을 재귀 적으로 호출하여 주어진 숫자의 계승을 계산합니다.

DECLARE 
   num number; 
   factorial number;  
   
FUNCTION fact(x number) 
RETURN number  
IS 
   f number; 
BEGIN 
   IF x=0 THEN 
      f := 1; 
   ELSE 
      f := x * fact(x-1); 
   END IF; 
RETURN f; 
END;  

BEGIN 
   num:= 6; 
   factorial := fact(num); 
   dbms_output.put_line(' Factorial '|| num || ' is ' || factorial); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Factorial 6 is 720 
  
PL/SQL procedure successfully completed.

이 장에서는 PL / SQL의 커서에 대해 설명합니다. Oracle은 SQL 문을 처리하기 위해 컨텍스트 영역으로 알려진 메모리 영역을 생성합니다. 여기에는 문 처리에 필요한 모든 정보가 포함됩니다. 예 : 처리 된 행 수 등

cursor이 컨텍스트 영역에 대한 포인터입니다. PL / SQL은 커서를 통해 컨텍스트 영역을 제어합니다. 커서는 SQL 문이 리턴 한 행 (하나 이상)을 보유합니다. 커서가 보유하고있는 행 세트를active set.

한 번에 하나씩 SQL 문이 리턴 한 행을 페치하고 처리하기 위해 프로그램에서 참조 될 수 있도록 커서의 이름을 지정할 수 있습니다. 커서에는 두 가지 유형이 있습니다.

  • 암시 적 커서
  • 명시 적 커서

암시 적 커서

암시 적 커서는 명령문에 대한 명시 적 커서가없는 경우 SQL 문이 실행될 때마다 Oracle에 의해 자동으로 생성됩니다. 프로그래머는 암시 적 커서와 그 안에있는 정보를 제어 할 수 없습니다.

DML 문 (INSERT, UPDATE 및 DELETE)이 실행될 때마다 암시 적 커서가이 문과 연결됩니다. INSERT 조작의 경우 커서는 삽입해야하는 데이터를 보유합니다. UPDATE 및 DELETE 조작의 경우 커서는 영향을받을 행을 식별합니다.

PL / SQL에서는 가장 최근의 암시 적 커서를 다음과 같이 참조 할 수 있습니다. SQL cursor, 항상 다음과 같은 속성이 있습니다. %FOUND, %ISOPEN, %NOTFOUND, 및 %ROWCOUNT. SQL 커서에는 추가 속성이 있습니다.%BULK_ROWCOUNT%BULK_EXCEPTIONS와 함께 사용하도록 설계되었습니다. FORALL성명서. 다음 표는 가장 많이 사용되는 속성에 대한 설명을 제공합니다-

S. 아니 속성 및 설명
1

%FOUND

INSERT, UPDATE 또는 DELETE 문이 하나 이상의 행에 영향을 주거나 SELECT INTO 문이 하나 이상의 행을 반환하면 TRUE를 반환합니다. 그렇지 않으면 FALSE를 반환합니다.

2

%NOTFOUND

% FOUND의 논리적 반대입니다. INSERT, UPDATE 또는 DELETE 문이 행에 영향을주지 않았거나 SELECT INTO 문이 행을 반환하지 않으면 TRUE를 반환합니다. 그렇지 않으면 FALSE를 반환합니다.

%ISOPEN

암시 적 커서에 대해서는 항상 FALSE를 반환합니다. Oracle은 관련 SQL 문을 실행 한 후 SQL 커서를 자동으로 닫기 때문입니다.

4

%ROWCOUNT

INSERT, UPDATE 또는 DELETE 문의 영향을 받거나 SELECT INTO 문에서 반환 된 행 수를 반환합니다.

모든 SQL 커서 속성은 다음과 같이 액세스됩니다. sql%attribute_name 예에서 아래와 같이.

이전 장에서 만들고 사용했던 CUSTOMERS 테이블을 사용할 것입니다.

Select * from customers;  

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+

다음 프로그램은 테이블을 업데이트하고 각 고객의 급여를 500 씩 인상하고 SQL%ROWCOUNT 영향을받는 행의 수를 결정하는 속성-

DECLARE  
   total_rows number(2); 
BEGIN 
   UPDATE customers 
   SET salary = salary + 500; 
   IF sql%notfound THEN 
      dbms_output.put_line('no customers selected'); 
   ELSIF sql%found THEN 
      total_rows := sql%rowcount;
      dbms_output.put_line( total_rows || ' customers selected '); 
   END IF;  
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

6 customers selected  

PL/SQL procedure successfully completed.

고객 테이블의 레코드를 확인하면 행이 업데이트되었음을 ​​알 수 있습니다.

Select * from customers;  

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2500.00 | 
|  2 | Khilan   |  25 | Delhi     |  2000.00 | 
|  3 | kaushik  |  23 | Kota      |  2500.00 | 
|  4 | Chaitali |  25 | Mumbai    |  7000.00 | 
|  5 | Hardik   |  27 | Bhopal    |  9000.00 | 
|  6 | Komal    |  22 | MP        |  5000.00 | 
+----+----------+-----+-----------+----------+

명시 적 커서

명시 적 커서는 프로그래머가 정의한 커서입니다. context area. PL / SQL 블록의 선언 섹션에서 명시 적 커서를 정의해야합니다. 하나 이상의 행을 반환하는 SELECT 문에서 생성됩니다.

명시 적 커서를 만드는 구문은 다음과 같습니다.

CURSOR cursor_name IS select_statement;

명시 적 커서 작업에는 다음 단계가 포함됩니다.

  • 메모리 초기화를위한 커서 선언
  • 메모리 할당을위한 커서 열기
  • 데이터 검색을 위해 커서 가져 오기
  • 커서를 닫아 할당 된 메모리 해제

커서 선언

커서를 선언하면 커서가 이름과 연관된 SELECT 문으로 정의됩니다. 예를 들면-

CURSOR c_customers IS 
   SELECT id, name, address FROM customers;

커서 열기

커서를 열면 커서에 대한 메모리가 할당되고 SQL 문에서 반환 된 행을 가져올 준비가됩니다. 예를 들어, 위에서 정의한 커서를 다음과 같이 엽니 다.

OPEN c_customers;

커서 가져 오기

커서를 가져 오려면 한 번에 한 행에 액세스해야합니다. 예를 들어, 다음과 같이 위에 열린 커서에서 행을 가져옵니다.

FETCH c_customers INTO c_id, c_name, c_addr;

커서 닫기

커서를 닫는다는 것은 할당 된 메모리를 해제하는 것을 의미합니다. 예를 들어, 위에서 연 커서를 다음과 같이 닫습니다.

CLOSE c_customers;

다음은 명시 적 커서 & minua;의 개념을 설명하는 완전한 예입니다.

DECLARE 
   c_id customers.id%type; 
   c_name customer.name%type; 
   c_addr customers.address%type; 
   CURSOR c_customers is 
      SELECT id, name, address FROM customers; 
BEGIN 
   OPEN c_customers; 
   LOOP 
   FETCH c_customers into c_id, c_name, c_addr; 
      EXIT WHEN c_customers%notfound; 
      dbms_output.put_line(c_id || ' ' || c_name || ' ' || c_addr); 
   END LOOP; 
   CLOSE c_customers; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

1 Ramesh Ahmedabad  
2 Khilan Delhi  
3 kaushik Kota     
4 Chaitali Mumbai  
5 Hardik Bhopal   
6 Komal MP  
  
PL/SQL procedure successfully completed.

이 장에서는 PL / SQL의 레코드에 대해 설명합니다. ㅏrecord다양한 종류의 데이터 항목을 보유 할 수있는 데이터 구조입니다. 레코드는 데이터베이스 테이블의 행과 유사한 여러 필드로 구성됩니다.

예를 들어, 도서관에서 책을 추적하려고합니다. 제목, 저자, 주제, 책 ID와 같은 각 책에 대한 다음 속성을 추적 할 수 있습니다. 이러한 각 항목에 대한 필드가 포함 된 레코드를 사용하면 BOOK을 논리 단위로 취급 할 수 있으며 정보를 더 나은 방식으로 구성하고 나타낼 수 있습니다.

PL / SQL은 다음 유형의 레코드를 처리 할 수 ​​있습니다.

  • Table-based
  • 커서 기반 레코드
  • 사용자 정의 레코드

테이블 기반 레코드

% ROWTYPE 속성을 사용하면 프로그래머가 table-basedcursorbased 기록.

다음 예는 table-based기록. 이전 장에서 만들고 사용했던 CUSTOMERS 테이블을 사용할 것입니다.

DECLARE 
   customer_rec customers%rowtype; 
BEGIN 
   SELECT * into customer_rec 
   FROM customers 
   WHERE id = 5;  
   dbms_output.put_line('Customer ID: ' || customer_rec.id); 
   dbms_output.put_line('Customer Name: ' || customer_rec.name); 
   dbms_output.put_line('Customer Address: ' || customer_rec.address); 
   dbms_output.put_line('Customer Salary: ' || customer_rec.salary); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Customer ID: 5 
Customer Name: Hardik 
Customer Address: Bhopal 
Customer Salary: 9000 
 
PL/SQL procedure successfully completed.

커서 기반 레코드

다음 예는 cursor-based기록. 이전 장에서 만들고 사용했던 CUSTOMERS 테이블을 사용할 것입니다.

DECLARE 
   CURSOR customer_cur is 
      SELECT id, name, address  
      FROM customers; 
   customer_rec customer_cur%rowtype; 
BEGIN 
   OPEN customer_cur; 
   LOOP 
      FETCH customer_cur into customer_rec; 
      EXIT WHEN customer_cur%notfound; 
      DBMS_OUTPUT.put_line(customer_rec.id || ' ' || customer_rec.name); 
   END LOOP; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

1 Ramesh 
2 Khilan 
3 kaushik 
4 Chaitali 
5 Hardik 
6 Komal  

PL/SQL procedure successfully completed.

사용자 정의 레코드

PL / SQL은 다양한 레코드 구조를 정의 할 수있는 사용자 정의 레코드 유형을 제공합니다. 이러한 레코드는 서로 다른 필드로 구성됩니다. 도서관에서 책을 추적하고 싶다고 가정 해 보겠습니다. 각 책에 대한 다음 속성을 추적 할 수 있습니다.

  • Title
  • Author
  • Subject
  • 도서 ID

레코드 정의

레코드 유형은 다음과 같이 정의됩니다.

TYPE 
type_name IS RECORD 
  ( field_name1  datatype1  [NOT NULL]  [:= DEFAULT EXPRESSION], 
   field_name2   datatype2   [NOT NULL]  [:= DEFAULT EXPRESSION], 
   ... 
   field_nameN  datatypeN  [NOT NULL]  [:= DEFAULT EXPRESSION); 
record-name  type_name;

도서 기록은 다음과 같이 선언됩니다.

DECLARE 
TYPE books IS RECORD 
(title  varchar(50), 
   author  varchar(50), 
   subject varchar(100), 
   book_id   number); 
book1 books; 
book2 books;

필드 액세스

레코드의 모든 필드에 액세스하려면 점을 사용합니다. (.)운영자. 멤버 액세스 연산자는 레코드 변수 이름과 액세스하려는 필드 사이의 마침표로 코딩됩니다. 다음은 레코드 사용을 설명하는 예입니다.

DECLARE 
   type books is record 
      (title varchar(50), 
      author varchar(50), 
      subject varchar(100), 
      book_id number); 
   book1 books; 
   book2 books; 
BEGIN 
   -- Book 1 specification 
   book1.title  := 'C Programming'; 
   book1.author := 'Nuha Ali ';  
   book1.subject := 'C Programming Tutorial'; 
   book1.book_id := 6495407;  
   -- Book 2 specification 
   book2.title := 'Telecom Billing'; 
   book2.author := 'Zara Ali'; 
   book2.subject := 'Telecom Billing Tutorial'; 
   book2.book_id := 6495700;  
  
  -- Print book 1 record 
   dbms_output.put_line('Book 1 title : '|| book1.title); 
   dbms_output.put_line('Book 1 author : '|| book1.author); 
   dbms_output.put_line('Book 1 subject : '|| book1.subject); 
   dbms_output.put_line('Book 1 book_id : ' || book1.book_id); 
   
   -- Print book 2 record 
   dbms_output.put_line('Book 2 title : '|| book2.title); 
   dbms_output.put_line('Book 2 author : '|| book2.author); 
   dbms_output.put_line('Book 2 subject : '|| book2.subject); 
   dbms_output.put_line('Book 2 book_id : '|| book2.book_id); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Book 1 title : C Programming 
Book 1 author : Nuha Ali 
Book 1 subject : C Programming Tutorial 
Book 1 book_id : 6495407 
Book 2 title : Telecom Billing 
Book 2 author : Zara Ali 
Book 2 subject : Telecom Billing Tutorial 
Book 2 book_id : 6495700  

PL/SQL procedure successfully completed.

서브 프로그램 매개 변수로 기록

다른 변수를 전달하는 것처럼 레코드를 서브 프로그램 매개 변수로 전달할 수 있습니다. 위의 예에서 액세스 한 것과 동일한 방식으로 레코드 필드에 액세스 할 수도 있습니다.

DECLARE 
   type books is record 
      (title  varchar(50), 
      author  varchar(50), 
      subject varchar(100), 
      book_id   number); 
   book1 books; 
   book2 books;  
PROCEDURE printbook (book books) IS 
BEGIN 
   dbms_output.put_line ('Book  title :  ' || book.title); 
   dbms_output.put_line('Book  author : ' || book.author); 
   dbms_output.put_line( 'Book  subject : ' || book.subject); 
   dbms_output.put_line( 'Book book_id : ' || book.book_id); 
END; 
   
BEGIN 
   -- Book 1 specification 
   book1.title  := 'C Programming'; 
   book1.author := 'Nuha Ali ';  
   book1.subject := 'C Programming Tutorial'; 
   book1.book_id := 6495407;
   
   -- Book 2 specification 
   book2.title := 'Telecom Billing'; 
   book2.author := 'Zara Ali'; 
   book2.subject := 'Telecom Billing Tutorial'; 
   book2.book_id := 6495700;  
   
   -- Use procedure to print book info 
   printbook(book1); 
   printbook(book2); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Book  title : C Programming 
Book  author : Nuha Ali 
Book subject : C Programming Tutorial 
Book  book_id : 6495407 
Book title : Telecom Billing 
Book author : Zara Ali 
Book subject : Telecom Billing Tutorial 
Book book_id : 6495700  

PL/SQL procedure successfully completed.

이 장에서는 PL / SQL의 예외에 대해 설명합니다. 예외는 프로그램 실행 중 오류 조건입니다. PL / SQL은 프로그래머가EXCEPTION프로그램에서 차단하고 오류 조건에 대해 적절한 조치가 취해집니다. 두 가지 유형의 예외가 있습니다.

  • 시스템 정의 예외
  • 사용자 정의 예외

예외 처리를위한 구문

예외 처리를위한 일반적인 구문은 다음과 같습니다. 여기에서 처리 할 수있는 한 많은 예외를 나열 할 수 있습니다. 기본 예외는 다음을 사용하여 처리됩니다.WHEN others THEN

DECLARE 
   <declarations section> 
BEGIN 
   <executable command(s)> 
EXCEPTION 
   <exception handling goes here > 
   WHEN exception1 THEN  
      exception1-handling-statements  
   WHEN exception2  THEN  
      exception2-handling-statements  
   WHEN exception3 THEN  
      exception3-handling-statements 
   ........ 
   WHEN others THEN 
      exception3-handling-statements 
END;

개념을 설명하는 코드를 작성해 보겠습니다. 이전 장에서 만들고 사용했던 CUSTOMERS 테이블을 사용할 것입니다.

DECLARE 
   c_id customers.id%type := 8; 
   c_name customerS.Name%type; 
   c_addr customers.address%type; 
BEGIN 
   SELECT  name, address INTO  c_name, c_addr 
   FROM customers 
   WHERE id = c_id;  
   DBMS_OUTPUT.PUT_LINE ('Name: '||  c_name); 
   DBMS_OUTPUT.PUT_LINE ('Address: ' || c_addr); 

EXCEPTION 
   WHEN no_data_found THEN 
      dbms_output.put_line('No such customer!'); 
   WHEN others THEN 
      dbms_output.put_line('Error!'); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

No such customer!  

PL/SQL procedure successfully completed.

위 프로그램은 ID가 부여 된 고객의 이름과 주소를 표시합니다. 데이터베이스에 ID 값이 8 인 고객이 없으므로 프로그램은 런타임 예외를 발생시킵니다.NO_DATA_FOUND에서 캡처됩니다. EXCEPTION block.

예외 발생

내부 데이터베이스 오류가있을 때마다 데이터베이스 서버에서 예외가 자동으로 발생하지만 프로그래머는 명령을 사용하여 명시 적으로 예외를 발생시킬 수 있습니다. RAISE. 다음은 예외를 발생시키는 간단한 구문입니다.

DECLARE 
   exception_name EXCEPTION; 
BEGIN 
   IF condition THEN 
      RAISE exception_name; 
   END IF; 
EXCEPTION 
   WHEN exception_name THEN 
   statement; 
END;

Oracle 표준 예외 또는 사용자 정의 예외를 발생시킬 때 위 구문을 사용할 수 있습니다. 다음 섹션에서는 사용자 정의 예외를 발생시키는 예를 제공합니다. 비슷한 방법으로 Oracle 표준 예외를 발생시킬 수 있습니다.

사용자 정의 예외

PL / SQL을 사용하면 프로그램의 필요에 따라 고유 한 예외를 정의 할 수 있습니다. 사용자 정의 예외를 선언 한 다음 RAISE 문 또는 프로 시저를 사용하여 명시 적으로 발생시켜야합니다.DBMS_STANDARD.RAISE_APPLICATION_ERROR.

예외를 선언하는 구문은 다음과 같습니다.

DECLARE 
   my-exception EXCEPTION;

다음 예는 개념을 보여줍니다. 이 프로그램은 고객 ID를 요구합니다. 사용자가 잘못된 ID를 입력하면 예외invalid_id 제기됩니다.

DECLARE 
   c_id customers.id%type := &cc_id; 
   c_name customerS.Name%type; 
   c_addr customers.address%type;  
   -- user defined exception 
   ex_invalid_id  EXCEPTION; 
BEGIN 
   IF c_id <= 0 THEN 
      RAISE ex_invalid_id; 
   ELSE 
      SELECT  name, address INTO  c_name, c_addr 
      FROM customers 
      WHERE id = c_id;
      DBMS_OUTPUT.PUT_LINE ('Name: '||  c_name);  
      DBMS_OUTPUT.PUT_LINE ('Address: ' || c_addr); 
   END IF; 

EXCEPTION 
   WHEN ex_invalid_id THEN 
      dbms_output.put_line('ID must be greater than zero!'); 
   WHEN no_data_found THEN 
      dbms_output.put_line('No such customer!'); 
   WHEN others THEN 
      dbms_output.put_line('Error!');  
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Enter value for cc_id: -6 (let's enter a value -6) 
old  2: c_id customers.id%type := &cc_id; 
new  2: c_id customers.id%type := -6; 
ID must be greater than zero! 
 
PL/SQL procedure successfully completed.

사전 정의 된 예외

PL / SQL은 프로그램이 데이터베이스 규칙을 위반할 때 실행되는 미리 정의 된 많은 예외를 제공합니다. 예를 들어 사전 정의 된 예외 NO_DATA_FOUND는 SELECT INTO 문이 행을 반환하지 않을 때 발생합니다. 다음 표는 몇 가지 중요한 사전 정의 된 예외를 나열합니다.

예외 Oracle 오류 SQLCODE 기술
ACCESS_INTO_NULL 06530 -6530 null 개체에 자동으로 값이 할당되면 발생합니다.
CASE_NOT_FOUND 06592 -6592 CASE 문의 WHEN 절에서 선택 사항이 선택되지 않고 ELSE 절이 없을 때 발생합니다.
COLLECTION_IS_NULL 06531 -6531 프로그램이 EXISTS 이외의 컬렉션 메서드를 초기화되지 않은 중첩 테이블 또는 varray에 적용하려고 시도하거나 프로그램이 초기화되지 않은 중첩 테이블 또는 varray의 요소에 값을 할당하려고 할 때 발생합니다.
DUP_VAL_ON_INDEX 00001 -1 고유 인덱스가있는 열에 중복 값을 저장하려고하면 발생합니다.
INVALID_CURSOR 01001 -1001 열리지 않은 커서를 닫는 것과 같이 허용되지 않는 커서 조작을 시도 할 때 발생합니다.
잘못된 번호 01722 -1722 문자열이 유효한 숫자를 나타내지 않아 문자열을 숫자로 변환하지 못할 때 발생합니다.
LOGIN_DENIED 01017 -1017 프로그램이 잘못된 사용자 이름 또는 암호를 사용하여 데이터베이스에 로그온하려고 할 때 발생합니다.
데이터가 없습니다 01403 +100 SELECT INTO 문이 행을 반환하지 않을 때 발생합니다.
NOT_LOGGED_ON 01012 -1012 데이터베이스에 연결되지 않고 데이터베이스 호출이 발행 될 때 발생합니다.
PROGRAM_ERROR 06501 -6501 PL / SQL에 내부 문제가있을 때 발생합니다.
ROWTYPE_MISMATCH 06504 -6504 데이터 유형이 호환되지 않는 변수에서 커서가 값을 가져올 때 발생합니다.
SELF_IS_NULL 30625 -30625 멤버 메서드가 호출되었지만 개체 형식의 인스턴스가 초기화되지 않았을 때 발생합니다.
STORAGE_ERROR 06500 -6500 PL / SQL의 메모리가 부족하거나 메모리가 손상되었을 때 발생합니다.
TOO_MANY_ROWS 01422 -1422 SELECT INTO 문이 둘 이상의 행을 반환 할 때 발생합니다.
VALUE_ERROR 06502 -6502 산술, 변환, 자르기 또는 sizeconstraint 오류가 발생하면 발생합니다.
ZERO_DIVIDE 01476 1476 년 숫자를 0으로 나누려고 할 때 발생합니다.

이 장에서는 PL / SQL의 트리거에 대해 설명합니다. 트리거는 일부 이벤트가 발생할 때 자동으로 실행되거나 실행되는 저장된 프로그램입니다. 실제로 트리거는 다음 이벤트에 대한 응답으로 실행되도록 작성됩니다.

  • database manipulation (DML) 문 (DELETE, INSERT 또는 UPDATE)

  • database definition (DDL) 문 (CREATE, ALTER 또는 DROP).

  • database operation (SERVERERROR, LOGON, LOGOFF, STARTUP 또는 SHUTDOWN).

이벤트가 연결된 테이블, 뷰, 스키마 또는 데이터베이스에서 트리거를 정의 할 수 있습니다.

트리거의 이점

트리거는 다음과 같은 목적으로 작성 될 수 있습니다.

  • 일부 파생 열 값 자동 생성
  • 참조 무결성 적용
  • 이벤트 로깅 및 테이블 액세스에 대한 정보 저장
  • Auditing
  • 테이블의 동기식 복제
  • 보안 권한 부여
  • 유효하지 않은 거래 방지

트리거 생성

트리거를 생성하는 구문은 다음과 같습니다.

CREATE [OR REPLACE ] TRIGGER trigger_name  
{BEFORE | AFTER | INSTEAD OF }  
{INSERT [OR] | UPDATE [OR] | DELETE}  
[OF col_name]  
ON table_name  
[REFERENCING OLD AS o NEW AS n]  
[FOR EACH ROW]  
WHEN (condition)   
DECLARE 
   Declaration-statements 
BEGIN  
   Executable-statements 
EXCEPTION 
   Exception-handling-statements 
END;

어디,

  • CREATE [OR REPLACE] 트리거 trigger_name의 것은 - 만들거나 함께 기존 트리거를 대체 trigger_name의 .

  • {이전 | 이후 | INSTEAD OF}-트리거가 실행되는시기를 지정합니다. INSTEAD OF 절은 뷰에서 트리거를 만드는 데 사용됩니다.

  • {INSERT [OR] | 업데이트 [또는] | DELETE}-이것은 DML 작업을 지정합니다.

  • [OF col_name]-업데이트 될 열 이름을 지정합니다.

  • [ON table_name]-트리거와 관련된 테이블의 이름을 지정합니다.

  • [OLD AS o NEW AS n]-INSERT, UPDATE 및 DELETE와 같은 다양한 DML 문에 대한 새 값과 이전 값을 참조 할 수 있습니다.

  • [FOR EACH ROW]-행 레벨 트리거를 지정합니다. 즉, 영향을받는 각 행에 대해 트리거가 실행됩니다. 그렇지 않으면 트리거는 테이블 레벨 트리거라고하는 SQL 문이 실행될 때 한 번만 실행됩니다.

  • WHEN (조건)-트리거가 실행되는 행에 대한 조건을 제공합니다. 이 절은 행 수준 트리거에만 유효합니다.

먼저 이전 장에서 만들고 사용한 CUSTOMERS 테이블을 사용합니다.

Select * from customers;  

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+

다음 프로그램은 row-levelCUSTOMERS 테이블에서 수행 된 INSERT 또는 UPDATE 또는 DELETE 작업에 대해 실행되는 고객 테이블에 대한 트리거입니다. 이 트리거는 이전 값과 새 값 사이의 급여 차이를 표시합니다-

CREATE OR REPLACE TRIGGER display_salary_changes 
BEFORE DELETE OR INSERT OR UPDATE ON customers 
FOR EACH ROW 
WHEN (NEW.ID > 0) 
DECLARE 
   sal_diff number; 
BEGIN 
   sal_diff := :NEW.salary  - :OLD.salary; 
   dbms_output.put_line('Old salary: ' || :OLD.salary); 
   dbms_output.put_line('New salary: ' || :NEW.salary); 
   dbms_output.put_line('Salary difference: ' || sal_diff); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Trigger created.

여기에서 다음 사항을 고려해야합니다.

  • OLD 및 NEW 참조는 테이블 레벨 트리거에 사용할 수 없으며 레코드 레벨 트리거에 사용할 수 있습니다.

  • 동일한 트리거에서 테이블을 쿼리하려면 AFTER 키워드를 사용해야합니다. 트리거는 초기 변경 사항이 적용되고 테이블이 일관된 상태로 돌아온 후에 만 ​​테이블을 쿼리하거나 다시 변경할 수 있기 때문입니다.

  • 위의 트리거는 테이블에서 DELETE 또는 INSERT 또는 UPDATE 작업 전에 실행되도록 작성되었지만 단일 또는 여러 작업에 대해 트리거를 작성할 수 있습니다 (예 : BEFORE DELETE). 테이블에서 DELETE 작업을 사용하여 삭제됩니다.

트리거 트리거

CUSTOMERS 테이블에서 몇 가지 DML 작업을 수행해 보겠습니다. 다음은 테이블에 새 레코드를 만드는 INSERT 문 하나입니다.

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (7, 'Kriti', 22, 'HP', 7500.00 );

CUSTOMERS 테이블에 레코드가 생성되면 위의 생성 트리거, display_salary_changes 실행되고 다음 결과가 표시됩니다.

Old salary: 
New salary: 7500 
Salary difference:

이것은 새로운 레코드이기 때문에 이전 급여를 사용할 수 없으며 위의 결과는 null이됩니다. 이제 CUSTOMERS 테이블에서 DML 작업을 하나 더 수행하겠습니다. UPDATE 문은 테이블의 기존 레코드를 업데이트합니다-

UPDATE customers 
SET salary = salary + 500 
WHERE id = 2;

CUSTOMERS 테이블에서 레코드가 업데이트되면 위의 생성 트리거, display_salary_changes 실행되고 다음 결과가 표시됩니다.

Old salary: 1500 
New salary: 2000 
Salary difference: 500

이 장에서는 PL / SQL의 패키지에 대해 설명합니다. 패키지는 논리적으로 관련된 PL / SQL 유형, 변수 및 하위 프로그램을 그룹화하는 스키마 객체입니다.

패키지에는 두 개의 필수 부분이 있습니다.

  • 패키지 사양
  • 패키지 본문 또는 정의

패키지 사양

사양은 패키지에 대한 인터페이스입니다. 그냥DECLARES패키지 외부에서 참조 할 수있는 유형, 변수, 상수, 예외, 커서 및 하위 프로그램. 즉, 패키지 내용에 대한 모든 정보를 포함하지만 하위 프로그램에 대한 코드는 제외합니다.

사양에있는 모든 개체가 호출됩니다. public사물. 패키지 사양에는 없지만 패키지 본문에 코딩 된 모든 하위 프로그램을private 목적.

다음 코드 조각은 단일 프로 시저가있는 패키지 사양을 보여줍니다. 패키지 내에 정의 된 많은 전역 변수와 여러 프로 시저 또는 함수를 가질 수 있습니다.

CREATE PACKAGE cust_sal AS 
   PROCEDURE find_sal(c_id customers.id%type); 
END cust_sal; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Package created.

패키지 본체

패키지 본문에는 패키지 사양 및 기타 개인 선언에 선언 된 다양한 메서드에 대한 코드가 있으며 이는 패키지 외부의 코드에서 숨겨집니다.

그만큼 CREATE PACKAGE BODY문은 패키지 본문을 만드는 데 사용됩니다. 다음 코드 스 니펫은cust_sal위에서 만든 패키지. PL / SQL-Variables 장 에서 언급 한대로 데이터베이스에 CUSTOMERS 테이블이 이미 생성되어 있다고 가정했습니다 .

CREATE OR REPLACE PACKAGE BODY cust_sal AS  
   
   PROCEDURE find_sal(c_id customers.id%TYPE) IS 
   c_sal customers.salary%TYPE; 
   BEGIN 
      SELECT salary INTO c_sal 
      FROM customers 
      WHERE id = c_id; 
      dbms_output.put_line('Salary: '|| c_sal); 
   END find_sal; 
END cust_sal; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Package body created.

패키지 요소 사용

패키지 요소 (변수, 절차 또는 함수)는 다음 구문으로 액세스됩니다.

package_name.element_name;

데이터베이스 스키마에 위의 패키지를 이미 만들었습니다. 다음 프로그램은 find_sal 의 방법 cust_sal 패키지 −

DECLARE 
   code customers.id%type := &cc_id; 
BEGIN 
   cust_sal.find_sal(code); 
END; 
/

SQL 프롬프트에서 위의 코드를 실행하면 고객 ID를 입력하라는 메시지가 표시되고 ID를 입력하면 다음과 같이 해당 급여가 표시됩니다.

Enter value for cc_id: 1 
Salary: 3000 

PL/SQL procedure successfully completed.

다음 프로그램은보다 완전한 패키지를 제공합니다. 우리는 다음 레코드와 함께 데이터베이스에 저장된 CUSTOMERS 테이블을 사용합니다.

Select * from customers;  

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  3000.00 | 
|  2 | Khilan   |  25 | Delhi     |  3000.00 | 
|  3 | kaushik  |  23 | Kota      |  3000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  7500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  9500.00 | 
|  6 | Komal    |  22 | MP        |  5500.00 | 
+----+----------+-----+-----------+----------+

패키지 사양

CREATE OR REPLACE PACKAGE c_package AS 
   -- Adds a customer 
   PROCEDURE addCustomer(c_id   customers.id%type, 
   c_name  customerS.No.ame%type, 
   c_age  customers.age%type, 
   c_addr customers.address%type,  
   c_sal  customers.salary%type); 
   
   -- Removes a customer 
   PROCEDURE delCustomer(c_id  customers.id%TYPE); 
   --Lists all customers 
   PROCEDURE listCustomer; 
  
END c_package; 
/

위의 코드가 SQL 프롬프트에서 실행되면 위의 패키지를 생성하고 다음 결과를 표시합니다.

Package created.

패키지 본문 생성

CREATE OR REPLACE PACKAGE BODY c_package AS 
   PROCEDURE addCustomer(c_id  customers.id%type, 
      c_name customerS.No.ame%type, 
      c_age  customers.age%type, 
      c_addr  customers.address%type,  
      c_sal   customers.salary%type) 
   IS 
   BEGIN 
      INSERT INTO customers (id,name,age,address,salary) 
         VALUES(c_id, c_name, c_age, c_addr, c_sal); 
   END addCustomer; 
   
   PROCEDURE delCustomer(c_id   customers.id%type) IS 
   BEGIN 
      DELETE FROM customers 
      WHERE id = c_id; 
   END delCustomer;  
   
   PROCEDURE listCustomer IS 
   CURSOR c_customers is 
      SELECT  name FROM customers; 
   TYPE c_list is TABLE OF customers.Name%type;  
   name_list c_list := c_list(); 
   counter integer :=0; 
   BEGIN 
      FOR n IN c_customers LOOP 
      counter := counter +1; 
      name_list.extend; 
      name_list(counter) := n.name; 
      dbms_output.put_line('Customer(' ||counter|| ')'||name_list(counter)); 
      END LOOP; 
   END listCustomer;
   
END c_package; 
/

위의 예는 nested table. 다음 장에서 중첩 테이블의 개념에 대해 설명합니다.

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Package body created.

패키지 사용

다음 프로그램은 c_package 패키지에 선언되고 정의 된 메소드를 사용합니다 .

DECLARE 
   code customers.id%type:= 8; 
BEGIN 
   c_package.addcustomer(7, 'Rajnish', 25, 'Chennai', 3500); 
   c_package.addcustomer(8, 'Subham', 32, 'Delhi', 7500); 
   c_package.listcustomer; 
   c_package.delcustomer(code); 
   c_package.listcustomer; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Customer(1): Ramesh  
Customer(2): Khilan  
Customer(3): kaushik     
Customer(4): Chaitali  
Customer(5): Hardik  
Customer(6): Komal 
Customer(7): Rajnish 
Customer(8): Subham 
Customer(1): Ramesh  
Customer(2): Khilan  
Customer(3): kaushik     
Customer(4): Chaitali  
Customer(5): Hardik  
Customer(6): Komal
Customer(7): Rajnish 

PL/SQL procedure successfully completed

이 장에서는 PL / SQL의 컬렉션에 대해 설명합니다. 콜렉션은 동일한 데이터 유형을 갖는 정렬 된 요소 그룹입니다. 각 요소는 컬렉션에서의 위치를 ​​나타내는 고유 한 아래 첨자로 식별됩니다.

PL / SQL은 세 가지 컬렉션 유형을 제공합니다.

  • 인덱스 별 테이블 또는 연관 배열
  • 중첩 테이블
  • 가변 크기 배열 또는 Varray

오라클 문서는 각 컬렉션 유형에 대해 다음과 같은 특성을 제공합니다.

수집 유형 요소 수 아래 첨자 유형 고밀도 또는 희소 만든 곳 객체 유형 속성 일 수 있음
연관 배열 (또는 인덱스 별 테이블) 무제한 문자열 또는 정수 어느 한 쪽 PL / SQL 블록에서만 아니
중첩 테이블 무제한 정수 조밀하게 시작하여 희박해질 수 있음 PL / SQL 블록 또는 스키마 수준
가변 크기 배열 (Varray) 경계 정수 항상 조밀함 PL / SQL 블록 또는 스키마 수준

우리는 이미 장에서 varray에 대해 논의했습니다. 'PL/SQL arrays'. 이 장에서는 PL / SQL 테이블에 대해 설명합니다.

두 유형의 PL / SQL 테이블, 즉 index-by 테이블과 중첩 테이블은 동일한 구조를 가지며 해당 행은 첨자 표기법을 사용하여 액세스됩니다. 그러나이 두 가지 유형의 테이블은 한 가지 측면에서 다릅니다. 중첩 테이블은 데이터베이스 열에 저장할 수 있지만 인덱스 별 테이블은 저장할 수 없습니다.

인덱스 별 테이블

index-by 테이블 (또는 associative array)는 key-value한 쌍. 각 키는 고유하며 해당 값을 찾는 데 사용됩니다. 키는 정수 또는 문자열 일 수 있습니다.

index-by 테이블은 다음 구문을 사용하여 생성됩니다. 여기에서 우리는index-by 테이블 이름 table_name, 키는 subscript_type이되고 관련 값은 element_type이됩니다.

TYPE type_name IS TABLE OF element_type [NOT NULL] INDEX BY subscript_type; 
 
table_name type_name;

다음 예제는 이름과 함께 정수 값을 저장하는 테이블을 생성하고 나중에 동일한 이름 목록을 인쇄하는 방법을 보여줍니다.

DECLARE 
   TYPE salary IS TABLE OF NUMBER INDEX BY VARCHAR2(20); 
   salary_list salary; 
   name   VARCHAR2(20); 
BEGIN 
   -- adding elements to the table 
   salary_list('Rajnish') := 62000; 
   salary_list('Minakshi') := 75000; 
   salary_list('Martin') := 100000; 
   salary_list('James') := 78000;  
   
   -- printing the table 
   name := salary_list.FIRST; 
   WHILE name IS NOT null LOOP 
      dbms_output.put_line 
      ('Salary of ' || name || ' is ' || TO_CHAR(salary_list(name))); 
      name := salary_list.NEXT(name); 
   END LOOP; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Salary of James is 78000 
Salary of Martin is 100000 
Salary of Minakshi is 75000 
Salary of Rajnish is 62000  

PL/SQL procedure successfully completed.

index-by 테이블의 요소는 %ROWTYPE 모든 데이터베이스 테이블 또는 %TYPE모든 데이터베이스 테이블 필드의. 다음 예는 개념을 보여줍니다. 우리는CUSTOMERS 데이터베이스에 저장된 테이블-

Select * from customers;  

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+

DECLARE 
   CURSOR c_customers is 
      select name from customers; 

   TYPE c_list IS TABLE of customers.Name%type INDEX BY binary_integer; 
   name_list c_list; 
   counter integer :=0; 
BEGIN 
   FOR n IN c_customers LOOP 
      counter := counter +1; 
      name_list(counter) := n.name; 
      dbms_output.put_line('Customer('||counter||'):'||name_lis t(counter)); 
   END LOOP; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Customer(1): Ramesh  
Customer(2): Khilan  
Customer(3): kaushik     
Customer(4): Chaitali  
Customer(5): Hardik  
Customer(6): Komal  

PL/SQL procedure successfully completed

중첩 테이블

nested table임의의 수의 요소가있는 1 차원 배열과 같습니다. 그러나 중첩 테이블은 다음 측면에서 배열과 다릅니다.

  • 배열에는 선언 된 수의 요소가 있지만 중첩 테이블에는 없습니다. 중첩 테이블의 크기는 동적으로 증가 할 수 있습니다.

  • 배열은 항상 조밀합니다. 즉, 항상 연속 된 첨자가 있습니다. 중첩 배열은 처음에는 조밀하지만 요소가 삭제되면 희소해질 수 있습니다.

중첩 테이블은 다음 구문을 사용하여 생성됩니다-

TYPE type_name IS TABLE OF element_type [NOT NULL]; 
 
table_name type_name;

이 선언은 다음 선언과 유사합니다. index-by 테이블이지만 INDEX BY 절.

중첩 테이블은 데이터베이스 열에 저장할 수 있습니다. 또한 단일 열 테이블을 더 큰 테이블과 조인하는 SQL 작업을 단순화하는 데 사용할 수 있습니다. 연관 배열은 데이터베이스에 저장할 수 없습니다.

다음 예제는 중첩 테이블의 사용을 설명합니다-

DECLARE 
   TYPE names_table IS TABLE OF VARCHAR2(10); 
   TYPE grades IS TABLE OF INTEGER;  
   names names_table; 
   marks grades; 
   total integer; 
BEGIN 
   names := names_table('Kavita', 'Pritam', 'Ayan', 'Rishav', 'Aziz'); 
   marks:= grades(98, 97, 78, 87, 92); 
   total := names.count; 
   dbms_output.put_line('Total '|| total || ' Students'); 
   FOR i IN 1 .. total LOOP 
      dbms_output.put_line('Student:'||names(i)||', Marks:' || marks(i)); 
   end loop; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Total 5 Students 
Student:Kavita, Marks:98 
Student:Pritam, Marks:97 
Student:Ayan, Marks:78 
Student:Rishav, Marks:87 
Student:Aziz, Marks:92  

PL/SQL procedure successfully completed.

의 요소 nested table 또한 %ROWTYPE데이터베이스 테이블의 % TYPE 또는 데이터베이스 테이블 필드의 % TYPE. 다음 예는 개념을 보여줍니다. 데이터베이스에 저장된 CUSTOMERS 테이블을 다음과 같이 사용합니다.

Select * from customers;  

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
+----+----------+-----+-----------+----------+

DECLARE 
   CURSOR c_customers is  
      SELECT  name FROM customers;  
   TYPE c_list IS TABLE of customerS.No.ame%type; 
   name_list c_list := c_list(); 
   counter integer :=0; 
BEGIN 
   FOR n IN c_customers LOOP 
      counter := counter +1; 
      name_list.extend; 
      name_list(counter)  := n.name; 
      dbms_output.put_line('Customer('||counter||'):'||name_list(counter)); 
   END LOOP; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Customer(1): Ramesh  
Customer(2): Khilan  
Customer(3): kaushik     
Customer(4): Chaitali  
Customer(5): Hardik  
Customer(6): Komal  

PL/SQL procedure successfully completed.

수집 방법

PL / SQL은 컬렉션을 더 쉽게 사용할 수 있도록 내장 된 컬렉션 메서드를 제공합니다. 다음 표는 방법과 목적을 나열합니다.

S. 아니 방법 이름 및 목적
1

EXISTS(n)

컬렉션의 n 번째 요소가 있으면 TRUE를 반환합니다. 그렇지 않으면 FALSE를 반환합니다.

2

COUNT

컬렉션에 현재 포함 된 요소 수를 반환합니다.

LIMIT

컬렉션의 최대 크기를 확인합니다.

4

FIRST

정수 첨자를 사용하는 컬렉션에서 첫 번째 (가장 작은) 인덱스 번호를 반환합니다.

5

LAST

정수 첨자를 사용하는 컬렉션에서 마지막 (가장 큰) 인덱스 번호를 반환합니다.

6

PRIOR(n)

컬렉션에서 인덱스 n 앞에 오는 인덱스 번호를 반환합니다.

7

NEXT(n)

인덱스 n에 이은 인덱스 번호를 반환합니다.

8

EXTEND

컬렉션에 하나의 null 요소를 추가합니다.

9

EXTEND(n)

n 개의 null 요소를 컬렉션에 추가합니다.

10

EXTEND(n,i)

추가 ni 번째 요소를 컬렉션에 복사합니다 .

11

TRIM

컬렉션의 끝에서 한 요소를 제거합니다.

12

TRIM(n)

제거 n 컬렉션의 끝에서 요소.

13

DELETE

컬렉션에서 모든 요소를 ​​제거하고 COUNT를 0으로 설정합니다.

14

DELETE(n)

제거합니다 nth숫자 키 또는 중첩 테이블이있는 연관 배열의 요소. 연관 배열에 문자열 키가있는 경우 키 값에 해당하는 요소가 삭제됩니다. 만약n null, DELETE(n) 아무것도하지 않습니다.

15

DELETE(m,n)

범위의 모든 요소를 ​​제거합니다. m..n연관 배열 또는 중첩 테이블에서. 만약m 보다 크다 n 또는 m 또는 n null, DELETE(m,n) 아무것도하지 않습니다.

수집 예외

다음 표는 컬렉션 예외와 발생시기를 제공합니다.

수집 예외 상황에서 발생
COLLECTION_IS_NULL 원자 적으로 null 컬렉션에서 작업하려고합니다.
데이터가 없습니다 아래 첨자는 삭제 된 요소 또는 연관 배열의 존재하지 않는 요소를 지정합니다.
SUBSCRIPT_BEYOND_COUNT 아래 첨자가 컬렉션의 요소 수를 초과합니다.
SUBSCRIPT_OUTSIDE_LIMIT 아래 첨자가 허용 범위를 벗어났습니다.
VALUE_ERROR 아래 첨자가 null이거나 키 유형으로 변환 할 수 없습니다. 이 예외는 키가PLS_INTEGER 범위이고 아래 첨자는이 범위 밖에 있습니다.

이 장에서는 PL / SQL의 트랜잭션에 대해 설명합니다. 데이터베이스transaction하나 이상의 관련 SQL 문으로 구성 될 수있는 원자 적 작업 단위입니다. 트랜잭션을 구성하는 SQL 문에 의해 발생하는 데이터베이스 수정이 집합 적으로 커밋 될 수 있기 때문에 원 자성이라고합니다. 즉, 데이터베이스에 영구적으로 만들거나 데이터베이스에서 롤백 (취소) 할 수 있습니다.

성공적으로 실행 된 SQL 문과 커밋 된 트랜잭션은 동일하지 않습니다. SQL 문이 성공적으로 실행 된 경우에도 해당 문이 포함 된 트랜잭션이 커밋되지 않으면 롤백 할 수 있으며 문에 의한 모든 변경 사항을 취소 할 수 있습니다.

거래 시작 및 종료

거래에는 beginning 그리고 end. 다음 이벤트 중 하나가 발생하면 트랜잭션이 시작됩니다.

  • 첫 번째 SQL 문은 데이터베이스에 연결 한 후 수행됩니다.

  • 트랜잭션이 완료된 후 발행 된 각각의 새 SQL 문에서.

다음 이벤트 중 하나가 발생하면 트랜잭션이 종료됩니다.

  • COMMIT 또는 ROLLBACK 명세서가 발행됩니다.

  • DDL 다음과 같은 진술 CREATE TABLE성명서가 발행됩니다. 이 경우 COMMIT가 자동으로 수행되기 때문입니다.

  • DCL 문과 같은 GRANT성명서가 발행됩니다. 이 경우 COMMIT가 자동으로 수행되기 때문입니다.

  • 사용자가 데이터베이스에서 연결을 끊습니다.

  • 사용자 종료 SQL*PLUS 발행함으로써 EXIT 명령을 내리면 COMMIT가 자동으로 수행됩니다.

  • SQL * Plus가 비정상적으로 종료됩니다. ROLLBACK 자동으로 수행됩니다.

  • DML문이 실패합니다. 이 경우 해당 DML 문을 실행 취소하기 위해 ROLLBACK이 자동으로 수행됩니다.

트랜잭션 커밋

트랜잭션은 SQL 명령 COMMIT를 실행하여 영구적으로 만듭니다. COMMIT 명령의 일반적인 구문은 다음과 같습니다.

COMMIT;

예를 들면

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (3, 'kaushik', 23, 'Kota', 2000.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (6, 'Komal', 22, 'MP', 4500.00 ); 

COMMIT;

트랜잭션 롤백

COMMIT없이 데이터베이스에 대한 변경은 ROLLBACK 명령을 사용하여 취소 할 수 있습니다.

ROLLBACK 명령의 일반 구문은 다음과 같습니다.

ROLLBACK [TO SAVEPOINT < savepoint_name>];

시스템 장애와 같은 전례없는 상황으로 인해 트랜잭션이 중단되면 커밋 이후 전체 트랜잭션이 자동으로 롤백됩니다. 사용하지 않는 경우savepoint, 다음 명령문을 사용하여 모든 변경 사항을 롤백하십시오.

ROLLBACK;

세이브 포인트

세이브 포인트는 체크 포인트를 설정하여 긴 트랜잭션을 더 작은 단위로 분할하는 데 도움이되는 일종의 마커입니다. 긴 트랜잭션 내에서 저장 점을 설정하여 필요한 경우 체크 포인트로 롤백 할 수 있습니다. 이것은SAVEPOINT 명령.

SAVEPOINT 명령의 일반 구문은 다음과 같습니다.

SAVEPOINT < savepoint_name >;

예를 들면

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (7, 'Rajnish', 27, 'HP', 9500.00 ); 

INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY) 
VALUES (8, 'Riddhi', 21, 'WB', 4500.00 ); 
SAVEPOINT sav1;
  
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000; 
ROLLBACK TO sav1;
  
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000 
WHERE ID = 7; 
UPDATE CUSTOMERS 
SET SALARY = SALARY + 1000 
WHERE ID = 8; 

COMMIT;

ROLLBACK TO sav1 −이 명령문은 저장 점 sav1을 표시 한 지점까지 모든 변경 사항을 롤백합니다.

그 후에 새로운 변경 사항이 시작됩니다.

자동 거래 제어

실행하려면 COMMIT 자동으로 INSERT, UPDATE 또는 DELETE 명령이 실행되면 다음을 설정할 수 있습니다. AUTOCOMMIT 환경 변수-

SET AUTOCOMMIT ON;

다음 명령을 사용하여 자동 커밋 모드를 끌 수 있습니다.

SET AUTOCOMMIT OFF;

이 장에서는 PL / SQL의 날짜와 시간에 대해 설명합니다. PL / SQL에는 두 가지 종류의 날짜 및 시간 관련 데이터 유형이 있습니다.

  • Datetime 데이터 유형
  • 간격 데이터 유형

Datetime 데이터 유형은-

  • DATE
  • TIMESTAMP
  • 시간대가있는 타임 스탬프
  • 현지 시간대가있는 타임 스탬프

간격 데이터 유형은-

  • INTERVAL YEAR TO MONTH
  • INTERVAL DAY TO SECOND

Datetime 및 Interval 데이터 유형에 대한 필드 값

양자 모두 datetimeinterval 데이터 유형은 다음으로 구성됩니다. fields. 이 필드의 값은 데이터 유형의 값을 결정합니다. 다음 표에는 날짜 시간 및 간격에 대한 필드와 가능한 값이 나열되어 있습니다.

분야 명 유효한 날짜 / 시간 값 유효한 간격 값
-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)은 시간 분수 초의 정밀도입니다.

9 (n) 부분은 DATE에 적용되지 않습니다.

0 ~ 59.9 (n), 여기서 9 (n)은 간격 소수 초의 정밀도입니다.
TIMEZONE_HOUR

-12 ~ 14 (범위는 일광 절약 시간 변경을 수용 함)

DATE 또는 TIMESTAMP에는 적용되지 않습니다.

해당 없음
TIMEZONE_MINUTE

00에서 59

DATE 또는 TIMESTAMP에는 적용되지 않습니다.

해당 없음
TIMEZONE_REGION DATE 또는 TIMESTAMP에는 적용되지 않습니다. 해당 없음
TIMEZONE_ABBR DATE 또는 TIMESTAMP에는 적용되지 않습니다. 해당 없음

Datetime 데이터 유형 및 함수

다음은 Datetime 데이터 유형입니다-

데이트

문자 및 숫자 데이터 유형 모두에 날짜 및 시간 정보를 저장합니다. 세기, 년, 월, 날짜,시, 분, 초에 대한 정보로 구성됩니다. 다음과 같이 지정됩니다.

타임 스탬프

DATE 데이터 유형의 확장입니다. 시간, 분, 초 값과 함께 DATE 데이터 유형의 년, 월, 일을 저장합니다. 정확한 시간 값을 저장하는 데 유용합니다.

시간대가있는 타임 스탬프

시간대 지역 이름 또는 해당 값에 시간대 오프셋을 포함하는 TIMESTAMP의 변형입니다. 시간대 오프셋은 현지 시간과 UTC의 차이 (시간 및 분)입니다. 이 데이터 유형은 여러 지역에서 날짜 정보를 수집하고 평가하는 데 유용합니다.

현지 시간대가있는 타임 스탬프

값에 시간대 오프셋을 포함하는 TIMESTAMP의 또 다른 변형입니다.

다음 표는 Datetime 함수를 제공합니다 (여기서 x는 datetime 값을 가짐)-

S. 아니 기능 이름 및 설명
1

ADD_MONTHS(x, y);

추가 y 개월 ~ x.

2

LAST_DAY(x);

해당 월의 마지막 날을 반환합니다.

MONTHS_BETWEEN(x, y);

개월 수를 반환합니다. xy.

4

NEXT_DAY(x, day);

다음의 날짜 반환 후를x.

5

NEW_TIME;

사용자가 지정한 시간대에서 시간 / 일 값을 반환합니다.

6

ROUND(x [, unit]);

라운드 x.

7

SYSDATE();

현재 날짜 시간을 반환합니다.

8

TRUNC(x [, unit]);

잘림 x.

타임 스탬프 함수 (여기서 x는 타임 스탬프 값을 가짐) −

S. 아니 기능 이름 및 설명
1

CURRENT_TIMESTAMP();

세션 시간대와 함께 현재 세션 시간을 포함하는 TIMESTAMP WITH TIME ZONE을 리턴합니다.

2

EXTRACT({ YEAR | MONTH | DAY | HOUR | MINUTE | SECOND } | { TIMEZONE_HOUR | TIMEZONE_MINUTE } | { TIMEZONE_REGION | } TIMEZONE_ABBR ) FROM x)

에서 년, 월, 일,시, 분, 초 또는 표준 시간대를 추출하고 반환합니다. x.

FROM_TZ(x, time_zone);

TIMESTAMP x 및 time_zone으로 지정된 시간대를 TIMESTAMP WITH TIMEZONE으로 변환합니다.

4

LOCALTIMESTAMP();

세션 시간대의 현지 시간을 포함하는 TIMESTAMP를 리턴합니다.

5

SYSTIMESTAMP();

데이터베이스 시간대와 함께 현재 데이터베이스 시간을 포함하는 TIMESTAMP WITH TIME ZONE을 리턴합니다.

6

SYS_EXTRACT_UTC(x);

TIMESTAMP WITH TIMEZONE x를 날짜 및 시간 (UTC)을 포함하는 TIMESTAMP로 변환합니다.

7

TO_TIMESTAMP(x, [format]);

문자열 x를 TIMESTAMP로 변환합니다.

8

TO_TIMESTAMP_TZ(x, [format]);

문자열 x를 TIMESTAMP WITH TIMEZONE으로 변환합니다.

다음 코드 스 니펫은 위 함수의 사용을 보여줍니다.

Example 1

SELECT SYSDATE FROM DUAL;

Output

08/31/2012 5:25:34 PM

Example 2

SELECT TO_CHAR(CURRENT_DATE, 'DD-MM-YYYY HH:MI:SS') FROM DUAL;

Output

31-08-2012 05:26:14

Example 3

SELECT ADD_MONTHS(SYSDATE, 5) FROM DUAL;

Output

01/31/2013 5:26:31 PM

Example 4

SELECT LOCALTIMESTAMP FROM DUAL;

Output

8/31/2012 5:26:55.347000 PM

간격 데이터 유형 및 함수

다음은 간격 데이터 유형입니다-

  • IINTERVAL YEAR TO MONTH-YEAR 및 MONTH datetime 필드를 사용하여 기간을 저장합니다.

  • INTERVAL DAY TO SECOND-일, 시간, 분, 초 단위로 일정 기간을 저장합니다.

간격 함수

S. 아니 기능 이름 및 설명
1

NUMTODSINTERVAL(x, interval_unit);

숫자 x를 INTERVAL DAY TO SECOND로 변환합니다.

2

NUMTOYMINTERVAL(x, interval_unit);

숫자 x를 INTERVAL YEAR TO MONTH로 변환합니다.

TO_DSINTERVAL(x);

문자열 x를 INTERVAL DAY TO SECOND로 변환합니다.

4

TO_YMINTERVAL(x);

문자열 x를 INTERVAL YEAR TO MONTH로 변환합니다.

이 장에서는 PL / SQL의 DBMS 출력에 대해 설명합니다. 그만큼DBMS_OUTPUT출력, 디버깅 정보를 표시하고 PL / SQL 블록, 하위 프로그램, 패키지 및 트리거에서 메시지를 보낼 수있는 내장 패키지입니다. 자습서 전체에서이 패키지를 이미 사용했습니다.

데이터베이스의 모든 사용자 테이블을 표시하는 작은 코드 조각을 살펴 보겠습니다. 모든 테이블 이름을 나열하려면 데이터베이스에서 시도하십시오-

BEGIN 
   dbms_output.put_line  (user || ' Tables in the database:'); 
   FOR t IN (SELECT table_name FROM user_tables) 
   LOOP 
      dbms_output.put_line(t.table_name); 
   END LOOP; 
END; 
/

DBMS_OUTPUT 하위 프로그램

DBMS_OUTPUT 패키지에는 다음과 같은 하위 프로그램이 있습니다.

S. 아니 서브 프로그램 및 목적
1

DBMS_OUTPUT.DISABLE;

메시지 출력을 비활성화합니다.

2

DBMS_OUTPUT.ENABLE(buffer_size IN INTEGER DEFAULT 20000);

메시지 출력을 활성화합니다. NULL 값buffer_size 무제한 버퍼 크기를 나타냅니다.

DBMS_OUTPUT.GET_LINE (line OUT VARCHAR2, status OUT INTEGER);

버퍼링 된 한 줄의 정보를 검색합니다.

4

DBMS_OUTPUT.GET_LINES (lines OUT CHARARR, numlines IN OUT INTEGER);

버퍼에서 라인 배열을 검색합니다.

5

DBMS_OUTPUT.NEW_LINE;

줄 끝 마커를 넣습니다.

6

DBMS_OUTPUT.PUT(item IN VARCHAR2);

버퍼에 부분 라인을 배치합니다.

7

DBMS_OUTPUT.PUT_LINE(item IN VARCHAR2);

버퍼에 라인을 배치합니다.

DECLARE 
   lines dbms_output.chararr; 
   num_lines number; 
BEGIN 
   -- enable the buffer with default size 20000 
   dbms_output.enable; 
   
   dbms_output.put_line('Hello Reader!'); 
   dbms_output.put_line('Hope you have enjoyed the tutorials!'); 
   dbms_output.put_line('Have a great time exploring pl/sql!'); 
  
   num_lines := 3; 
  
   dbms_output.get_lines(lines, num_lines); 
  
   FOR i IN 1..num_lines LOOP 
      dbms_output.put_line(lines(i)); 
   END LOOP; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Hello Reader! 
Hope you have enjoyed the tutorials! 
Have a great time exploring pl/sql!  

PL/SQL procedure successfully completed.

이 장에서는 객체 지향 PL / SQL에 대해 설명합니다. PL / SQL을 사용하면 객체 유형을 정의 할 수 있으므로 Oracle에서 객체 지향 데이터베이스를 설계하는 데 도움이됩니다. 개체 유형을 사용하면 복합 유형을 만들 수 있습니다. 객체를 사용하면 특정 데이터 구조와이를 작동하는 방법으로 실제 객체를 구현할 수 있습니다. 개체에는 속성과 메서드가 있습니다. 속성은 객체의 속성이며 객체의 상태를 저장하는 데 사용됩니다. 동작을 모델링하는 데 사용됩니다.

개체는 CREATE [OR REPLACE] TYPE 문을 사용하여 생성됩니다. 다음은 간단한address 몇 가지 속성으로 구성된 객체-

CREATE OR REPLACE TYPE address AS OBJECT 
(house_no varchar2(10), 
 street varchar2(30), 
 city varchar2(20), 
 state varchar2(10), 
 pincode varchar2(10) 
); 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type created.

객체를 하나 더 만들어 보겠습니다. customer 우리가 포장 할 곳 attributesmethods 함께 객체 지향적 인 느낌을 가지기 위해-

CREATE OR REPLACE TYPE customer AS OBJECT 
(code number(5), 
 name varchar2(30), 
 contact_no varchar2(12), 
 addr address, 
 member procedure display 
); 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type created.

개체 인스턴스화

객체 유형을 정의하면 객체에 대한 청사진이 제공됩니다. 이 개체를 사용하려면이 개체의 인스턴스를 만들어야합니다. 인스턴스 이름을 사용하여 개체의 속성과 메서드에 액세스 할 수 있습니다.the access operator (.) 다음과 같이-

DECLARE 
   residence address; 
BEGIN 
   residence := address('103A', 'M.G.Road', 'Jaipur', 'Rajasthan','201301'); 
   dbms_output.put_line('House No: '|| residence.house_no); 
   dbms_output.put_line('Street: '|| residence.street); 
   dbms_output.put_line('City: '|| residence.city); 
   dbms_output.put_line('State: '|| residence.state); 
   dbms_output.put_line('Pincode: '|| residence.pincode); 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

House No: 103A 
Street: M.G.Road 
City: Jaipur 
State: Rajasthan 
Pincode: 201301  

PL/SQL procedure successfully completed.

회원 방법

Member methods 조작에 사용됩니다 attributes개체의. 개체 유형을 선언하는 동안 멤버 메서드의 선언을 제공합니다. 개체 본문은 멤버 메서드에 대한 코드를 정의합니다. 개체 본문은 CREATE TYPE BODY 문을 사용하여 생성됩니다.

Constructors새 객체를 값으로 반환하는 함수입니다. 모든 개체에는 시스템 정의 생성자 메서드가 있습니다. 생성자의 이름은 객체 유형과 동일합니다. 예를 들면-

residence := address('103A', 'M.G.Road', 'Jaipur', 'Rajasthan','201301');

그만큼 comparison methods객체를 비교하는 데 사용됩니다. 객체를 비교하는 두 가지 방법이 있습니다.

지도 방법

그만큼 Map method값이 속성 값에 따라 달라지는 방식으로 구현 된 함수입니다. 예를 들어 고객 개체의 경우 고객 코드가 두 고객에 대해 동일하면 두 고객이 동일 할 수 있습니다. 따라서이 두 개체 간의 관계는 코드의 가치에 따라 달라집니다.

주문 방법

그만큼 Order method두 개체를 비교하기위한 내부 논리를 구현합니다. 예를 들어 직사각형 객체의 경우 직사각형은 양쪽이 더 큰 경우 다른 직사각형보다 큽니다.

지도 방식 사용

다음 사각형 객체를 사용하여 위의 개념을 이해해 보겠습니다.

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 member function enlarge( inc number) return rectangle, 
 member procedure display, 
 map member function measure return number 
); 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type created.

유형 본문 만들기-

CREATE OR REPLACE TYPE BODY rectangle AS 
   MEMBER FUNCTION enlarge(inc number) return rectangle IS 
   BEGIN 
      return rectangle(self.length + inc, self.width + inc); 
   END enlarge;  
   MEMBER PROCEDURE display IS 
   BEGIN  
      dbms_output.put_line('Length: '|| length); 
      dbms_output.put_line('Width: '|| width); 
   END display;  
   MAP MEMBER FUNCTION measure return number IS 
   BEGIN 
      return (sqrt(length*length + width*width)); 
   END measure; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type body created.

이제 직사각형 객체와 그 멤버 함수를 사용합니다.

DECLARE 
   r1 rectangle; 
   r2 rectangle; 
   r3 rectangle; 
   inc_factor number := 5; 
BEGIN 
   r1 := rectangle(3, 4); 
   r2 := rectangle(5, 7); 
   r3 := r1.enlarge(inc_factor); 
   r3.display;  
   IF (r1 > r2) THEN -- calling measure function 
      r1.display; 
   ELSE 
      r2.display; 
   END IF; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Length: 8 
Width: 9 
Length: 5 
Width: 7  

PL/SQL procedure successfully completed.

주문 방법 사용

자, same effect could be achieved using an order method. 주문 방법을 사용하여 사각형 객체를 다시 만들어 보겠습니다.

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 member procedure display, 
 order member function measure(r rectangle) return number 
); 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type created.

유형 본문 만들기-

CREATE OR REPLACE TYPE BODY rectangle AS 
   MEMBER PROCEDURE display IS 
   BEGIN 
      dbms_output.put_line('Length: '|| length); 
      dbms_output.put_line('Width: '|| width); 
   END display;  
   ORDER MEMBER FUNCTION measure(r rectangle) return number IS 
   BEGIN 
      IF(sqrt(self.length*self.length + self.width*self.width)> 
         sqrt(r.length*r.length + r.width*r.width)) then 
         return(1); 
      ELSE 
         return(-1); 
      END IF; 
   END measure; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type body created.

사각형 객체와 그 멤버 함수 사용-

DECLARE 
   r1 rectangle; 
   r2 rectangle; 
BEGIN 
   r1 := rectangle(23, 44); 
   r2 := rectangle(15, 17); 
   r1.display; 
   r2.display; 
   IF (r1 > r2) THEN -- calling measure function 
      r1.display; 
   ELSE 
      r2.display; 
   END IF; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Length: 23 
Width: 44 
Length: 15 
Width: 17 
Length: 23 
Width: 44 

PL/SQL procedure successfully completed.

PL / SQL 객체에 대한 상속

PL / SQL을 사용하면 기존 기본 개체에서 개체를 만들 수 있습니다. 상속을 구현하려면 기본 개체를 다음과 같이 선언해야합니다.NOT FINAL. 기본값은FINAL.

다음 프로그램은 PL / SQL 객체의 상속을 보여줍니다. 이름이 다른 개체를 만들어 보겠습니다.TableTop, 이것은 Rectangle 객체에서 상속됩니다. 이를 위해 기본 사각형 객체 를 만들어야합니다.

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 member function enlarge( inc number) return rectangle, 
 NOT FINAL member procedure display) NOT FINAL 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type created.

기본 유형 본문 만들기-

CREATE OR REPLACE TYPE BODY rectangle AS 
   MEMBER FUNCTION enlarge(inc number) return rectangle IS 
   BEGIN 
      return rectangle(self.length + inc, self.width + inc); 
   END enlarge;  
   MEMBER PROCEDURE display IS 
   BEGIN 
      dbms_output.put_line('Length: '|| length); 
      dbms_output.put_line('Width: '|| width); 
   END display; 
END; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type body created.

자식 개체 테이블 만들기 -

CREATE OR REPLACE TYPE tabletop UNDER rectangle 
(   
   material varchar2(20), 
   OVERRIDING member procedure display 
) 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type created.

자식 개체 tabletop에 대한 유형 본문 만들기

CREATE OR REPLACE TYPE BODY tabletop AS 
OVERRIDING MEMBER PROCEDURE display IS 
BEGIN 
   dbms_output.put_line('Length: '|| length); 
   dbms_output.put_line('Width: '|| width); 
   dbms_output.put_line('Material: '|| material); 
END display; 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type body created.

은 Using 탁상 개체와 해당 멤버 함수 -

DECLARE 
   t1 tabletop; 
   t2 tabletop; 
BEGIN 
   t1:= tabletop(20, 10, 'Wood'); 
   t2 := tabletop(50, 30, 'Steel'); 
   t1.display; 
   t2.display; 
END;
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Length: 20 
Width: 10 
Material: Wood 
Length: 50 
Width: 30 
Material: Steel  

PL/SQL procedure successfully completed.

PL / SQL의 추상 객체

그만큼 NOT INSTANTIABLE절을 사용하면 추상 객체를 선언 할 수 있습니다. 추상 객체는있는 그대로 사용할 수 없습니다. 기능을 사용하려면 이러한 개체의 하위 유형 또는 하위 유형을 만들어야합니다.

예를 들면

CREATE OR REPLACE TYPE rectangle AS OBJECT 
(length number, 
 width number, 
 NOT INSTANTIABLE NOT FINAL MEMBER PROCEDURE display)  
 NOT INSTANTIABLE NOT FINAL 
/

위의 코드가 SQL 프롬프트에서 실행되면 다음 결과가 생성됩니다.

Type created.