那么对于包内一个返回集合类型的函数,如:FUNCTION strsplit(p_list IN VARCHAR2, p_sep IN VARCHAR2 DEFAULT '|')
RETURN str_split
PIPELINED;
str_split为一个自定义集合类型:
TYPE "STR_SPLIT" IS TABLE OF VARCHAR2 (4000);
此时,无论将type str_split以公有,或私有方式 在包中声明,均无法正常使用sql方式调用,由于返回为集合,也不能用plsql的kkk:=str_split方式调用。此时,只能将str_split定义为oracle的自定义数据类型:
create or replace TYPE "STR_SPLIT" IS TABLE OF VARCHAR2 (4000)
然后去除包内公有或私有的type str_split定义,即可使用sql方式调用函数。