您的位置:首页 > 文旅 > 旅游 > Oracle(46)什么是集合(Collection)?

Oracle(46)什么是集合(Collection)?

2024/10/6 16:30:54 来源:https://blog.csdn.net/qq_43012298/article/details/139440781  浏览:    关键词:Oracle(46)什么是集合(Collection)?

在PL/SQL中,集合(Collection)是一种复合数据类型,用于存储一组相关的数据项。集合类似于数组,但提供了更多的功能和灵活性。PL/SQL支持三种类型的集合:

  1. 关联数组(Associative Arrays):也称为索引表,是一种键值对的集合,键可以是字符串或数字。
  2. 嵌套表(Nested Tables):是一种无界数组,可以存储任意数量的元素。
  3. 可变数组(VARRAYs):是一种定长数组,存储元素的个数在创建时指定。

关联数组(Associative Arrays)

关联数组是键值对的集合,键可以是字符串或数字。它们非常适合用于需要快速查找和更新的情况。

示例:使用关联数组
DECLARETYPE employee_salary_type IS TABLE OF NUMBER INDEX BY VARCHAR2(50);employee_salaries employee_salary_type;
BEGIN-- 添加数据employee_salaries('John') := 5000;employee_salaries('Jane') := 6000;employee_salaries('Alice') := 7000;-- 访问数据DBMS_OUTPUT.PUT_LINE('Salary of John: ' || employee_salaries('John'));DBMS_OUTPUT.PUT_LINE('Salary of Jane: ' || employee_salaries('Jane'));-- 更新数据employee_salaries('John') := 5500;DBMS_OUTPUT.PUT_LINE('Updated salary of John: ' || employee_salaries('John'));-- 删除数据employee_salaries.DELETE('Jane');IF employee_salaries.EXISTS('Jane') THENDBMS_OUTPUT.PUT_LINE('Salary of Jane: ' || employee_salaries('Jane'));ELSEDBMS_OUTPUT.PUT_LINE('Jane''s salary record does not exist.');END IF;
END;
/

嵌套表(Nested Tables)

嵌套表是一种无界数组,可以存储任意数量的元素。它们适用于需要动态调整大小的集合。

示例:使用嵌套表
DECLARETYPE employee_name_type IS TABLE OF VARCHAR2(50);employee_names employee_name_type;
BEGIN-- 初始化嵌套表employee_names := employee_name_type('John', 'Jane', 'Alice');-- 添加数据employee_names.EXTEND;employee_names(4) := 'Bob';-- 访问数据FOR i IN 1..employee_names.COUNT LOOPDBMS_OUTPUT.PUT_LINE('Employee ' || i || ': ' || employee_names(i));END LOOP;-- 更新数据employee_names(2) := 'Janet';DBMS_OUTPUT.PUT_LINE('Updated Employee 2: ' || employee_names(2));-- 删除数据employee_names.DELETE(3);FOR i IN 1..employee_names.COUNT LOOPDBMS_OUTPUT.PUT_LINE('Employee ' || i || ': ' || employee_names(i));END LOOP;
END;
/

可变数组(VARRAYs)

可变数组是一种定长数组,存储元素的个数在创建时指定。它们适用于元素数量固定或变化范围较小的情况。

示例:使用可变数组
DECLARETYPE employee_id_varray IS VARRAY(5) OF NUMBER;employee_ids employee_id_varray := employee_id_varray(1, 2, 3);
BEGIN-- 添加数据employee_ids.EXTEND;employee_ids(4) := 4;-- 访问数据FOR i IN 1..employee_ids.COUNT LOOPDBMS_OUTPUT.PUT_LINE('Employee ID ' || i || ': ' || employee_ids(i));END LOOP;-- 更新数据employee_ids(2) := 5;DBMS_OUTPUT.PUT_LINE('Updated Employee ID 2: ' || employee_ids(2));-- 删除数据employee_ids.DELETE(3);FOR i IN 1..employee_ids.COUNT LOOPDBMS_OUTPUT.PUT_LINE('Employee ID ' || i || ': ' || employee_ids(i));END LOOP;
END;
/

集合的常用操作

无论是哪种类型的集合,它们都支持一些常见的操作:

  1. 初始化(Initialization):使用构造函数或赋值语句初始化集合。
  2. 添加元素(Adding Elements):使用EXTEND方法扩展集合的大小,然后赋值。
  3. 访问元素(Accessing Elements):通过索引或键访问集合中的元素。
  4. 更新元素(Updating Elements):直接通过索引或键更新集合中的元素。
  5. 删除元素(Deleting Elements):使用DELETE方法删除集合中的元素。
  6. 遍历元素(Iterating Elements):使用FOR循环遍历集合中的所有元素。

示例:综合使用集合

以下示例展示了如何综合使用集合的各种操作。

DECLARETYPE employee_record IS RECORD (employee_id NUMBER,first_name VARCHAR2(50),last_name VARCHAR2(50),salary NUMBER);TYPE employee_table_type IS TABLE OF employee_record INDEX BY PLS_INTEGER;employee_table employee_table_type;v_employee employee_record;i PLS_INTEGER;
BEGIN-- 添加数据employee_table(1).employee_id := 1;employee_table(1).first_name := 'John';employee_table(1).last_name := 'Doe';employee_table(1).salary := 5000;employee_table(2).employee_id := 2;employee_table(2).first_name := 'Jane';employee_table(2).last_name := 'Smith';employee_table(2).salary := 6000;-- 访问数据FOR i IN 1..employee_table.COUNT LOOPv_employee := employee_table(i);DBMS_OUTPUT.PUT_LINE('Employee ID: ' || v_employee.employee_id || ', Name: ' || v_employee.first_name || ' ' || v_employee.last_name ||', Salary: ' || v_employee.salary);END LOOP;-- 更新数据employee_table(1).salary := 5500;DBMS_OUTPUT.PUT_LINE('Updated Salary of Employee 1: ' || employee_table(1).salary);-- 删除数据employee_table.DELETE(2);IF employee_table.EXISTS(2) THENDBMS_OUTPUT.PUT_LINE('Employee 2 still exists.');ELSEDBMS_OUTPUT.PUT_LINE('Employee 2 has been deleted.');END IF;-- 遍历剩余数据FOR i IN 1..employee_table.COUNT LOOPv_employee := employee_table(i);DBMS_OUTPUT.PUT_LINE('Employee ID: ' || v_employee.employee_id || ', Name: ' || v_employee.first_name || ' ' || v_employee.last_name ||', Salary: ' || v_employee.salary);END LOOP;
END;
/

总结

集合是PL/SQL中用于存储和操作一组相关数据项的复合数据类型。它们包括关联数组、嵌套表和可变数组三种类型,每种类型都有其独特的特点和适用场景。通过合理使用集合,可以显著提高PL/SQL程序的数据处理能力和效率。在使用集合时,需要掌握它们的初始化、添加、访问、更新、删除和遍历等基本操作。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com