PL/SQL学习笔记之集合

时间:2021-11-11 07:27:56

一:PL/SQL集合

集合是一个有序且存有相同的类型数据的数据结构。

PL/SQL提供了三种集合类型:

  • 索引表(关联数组)

  • 嵌套表

  • 数组

二:索引表:一个索引表(也叫关联数组)是一组键 - 值对。每个键是唯一的,并且用于定位对应的值。键可以是整数或字符串。【其实就是 Map类型】

1)创建索引表

TYPE type_name IS TABLE OF element_type [NOT NULL] INDEX BY subscript_type; //定义索引表类型:指明值类型和键类型

table_name type_name; //使用索引表类型定义索引表变量

2)例子

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; //为索引表add键值对
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;

三:嵌套表:大小可以动态的数组。【就是ArrayList】

1)创建嵌套表

TYPE type_name IS TABLE OF element_type [NOT NULL]; //声明嵌套表类型,指明元素的数据类型【不用指明大小!】

table_name type_name; //创建嵌套表变量

2)为嵌套表赋值

table_name := type_name(val1,val2...);

3)访问嵌套表元素

table_name(i)

4)例子

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;

四:数组

1:PL/SQL中,数组是VARRAY,其可存储相同类型元素的一个固定大小的连续集合。

2:声明数组类型:指定最大长度,存储在VARRAY元素的类型。

TYPE varray_type_name IS VARRAY(n) of <element_type>  #注意:这里不是创建数组,而是数组类型。即:声明一种类型,其  能存放n个  elementtype类型  的数据。

3:使用数组类型创建变量

array varray_type_name;

4:为数组变量赋值

array := varray_type_name(元素1,元素2,元素3...)

5:获取数组元素

array(i) #i是下标

例如:

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;

五:集合方法

S.N. 方法名称及用途
1 EXISTS(n)
返回TRUE,如果一个集合中的第n个元素的存在;否则返回FALSE
2 COUNT
返回集合当前包含的元素数量
3 LIMIT
检查集合的最大尺寸
4 FIRST
返回在使用整数下标集合的第一个(最小的)索引号
5 LAST
返回在使用整数下标集合的最后一个(最大的)索引号
6 PRIOR(n)
返回集合中索引n前面的索引号
7 NEXT(n)
返回索引n的下一个索引号
8 EXTEND
追加1个空元素到集合
9 EXTEND(n)
追加n个空元素到集合
10 EXTEND(n,i)
追加的第i个元素的集合的n个拷贝
11 TRIM
移除集合的末尾一个元素
12 TRIM(n)
移除一个集合末尾的n个元素
13 DELETE
移除一个集合中的所有元素,设置计数为0
14 DELETE(n)
移除关联数组用数字键或嵌套表中的第n个元素。如果关联数组有一个字符串键,对应于该键的值的元素将被删除。如果n为空,DELETE(N)什么都不做
15 DELETE(m,n)
移除关联数组或嵌套表范围m..n所有元素。如果m大于n或如果m大于或n是零,DELETE(M,N)什么也不做

六:集合异常

COLLECTION_IS_NULL 尝试在一个原子空(null)的集合操作
NO_DATA_FOUND 下标指定被删除的元素,或关联数组的一个不存在的元素
SUBSCRIPT_BEYOND_COUNT 下标超过了一个集合的元素数
SUBSCRIPT_OUTSIDE_LIMIT 下标超出了允许的范围
VALUE_ERROR 下标为空(null)或不可转换的键类型。如果该键被定义为PLS_INTEGER范围,下标是在该范围之外可能会出现这样的异常