PL / SQL-어레이

이 장에서는 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.