集合类型中的PL / SQL函数

时间:2018-06-25 07:11:14

标签: plsql plsql-package

所以我创建了一个具有多个属性的对象类型。

从该对象中,我还创建了一个集合类型。 假设:

create or replace type employees as table of employee; 

现在,我想使用集合对象来执行诸如GetAllEmployees(),GetEmployeesByJobType()之类的方法。这样我就可以在其他地方调用对象类型并执行方法:

v_list := employees.GetAllEmployees(); 与您要从程序包进行调用相同,但我想调用一个对象而不是程序包。

但是,我尝试像在对象中一样尝试指定和创建方法,但是无法编译。

现在,我知道我可以为包中的方法执行逻辑,但我想将其分开。

所以我的问题是:是否可以在对象集合内执行逻辑?

1 个答案:

答案 0 :(得分:2)

这可能是您正在寻找的示例:

create or replace type employeeObj as object (id number, name varchar2(100));

create or replace type employeeList is table of employeeObj;

create or replace type employeeListObj as object
(
    listOfEmployees employeeList,
    member procedure GetAllEmployees
); 

create or replace type body employeeListObj is
    member procedure GetAllEmployees is
    begin
        for i in listOfEmployees.first .. listOfEmployees.last loop
            dbms_output.put_line('Emp: ' || listOfEmployees(i).name );
        end loop;
    end;
end; 

工作原理:

SQL> declare
  2      vListEmp    employeeList;
  3      vListEmpObj employeeListObj;
  4  begin
  5      vListEmp := employeeList();
  6      vListEmp.extend(2);
  7      vListEmp(1) := employeeObj(1, 'John Smith');
  8      vListEmp(2) := employeeObj(2, 'Steve James');
  9
 10      vListEmpObj := new employeeListObj(vListEmp);
 11
 12      vListEmpObj.GetAllEmployees();
 13  end;
 14  /
Emp: John Smith
Emp: Steve James

PL/SQL procedure successfully completed.