存储过程中的嵌套表
下面显示的 PL/SQL 脚本在第 20 行无法执行:
declare
type string_table is table of varchar(100);
v_names string_table := string_table();
begin
v_names.EXTEND(3);
v_names(1) := 'name1';
v_names(2) := 'name2';
v_names(3) := 'name3';
dbms_output.put_line(v_names(1));
dbms_output.put_line(v_names(2));
dbms_output.put_line(v_names(3));
dbms_output.put_line(v_names.COUNT());
20 select * from table(v_names);
end;
以下是报告的错误消息:
ORA-06550: line 20, column 23: PLS-00642: local collection types are not allowed in SQL statements ORA-06550: line 20, column 17: PL/SQL: ORA-22905: cannot access rows from a non-nested table item ORA-06550: line 20, column 3: PL/SQL: SQL Statement ignored.
如何解决此问题的任何想法。
请注意,我编写此代码只是为了向 SO 发布此问题。类似的代码是一个更大的包的一部分...
提前致谢!
禅
The PL/SQL script shown below is failing to execute at line # 20:
declare
type string_table is table of varchar(100);
v_names string_table := string_table();
begin
v_names.EXTEND(3);
v_names(1) := 'name1';
v_names(2) := 'name2';
v_names(3) := 'name3';
dbms_output.put_line(v_names(1));
dbms_output.put_line(v_names(2));
dbms_output.put_line(v_names(3));
dbms_output.put_line(v_names.COUNT());
20 select * from table(v_names);
end;
The following are the error messages reported:
ORA-06550: line 20, column 23: PLS-00642: local collection types are not allowed in SQL statements ORA-06550: line 20, column 17: PL/SQL: ORA-22905: cannot access rows from a non-nested table item ORA-06550: line 20, column 3: PL/SQL: SQL Statement ignored.
Any ideas how to resolve this issue.
Please note I wrote this code only for the purpose of posting this question to SO. Similar code is part of a larger package...
Thanks in advance!
Zen
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
您只能对数据库中定义的类型使用 SQL(如 SELECT),使用 CREATE TYPE:
然后:
You can only use SQL (like SELECT) on types that are defined in the database, using CREATE TYPE:
Then: