最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

ORA-06531:Referencetouninitializedcollection问题解决

来源:动视网 责编:小采 时间:2020-11-09 10:32:55
文档

ORA-06531:Referencetouninitializedcollection问题解决

ORA-06531:Referencetouninitializedcollection问题解决:ORA-06531:Reference to uninitialized collection 问题解决错误信息:ORA-06531:Reference to uninitialized collection错误SQL代码:declare TYPE t_student_var IS TABLE OF VARCHAR2(100); v_tbl_n
推荐度:
导读ORA-06531:Referencetouninitializedcollection问题解决:ORA-06531:Reference to uninitialized collection 问题解决错误信息:ORA-06531:Reference to uninitialized collection错误SQL代码:declare TYPE t_student_var IS TABLE OF VARCHAR2(100); v_tbl_n


ORA-06531:Reference to uninitialized collection 问题解决

错误信息:

ORA-06531:Reference to uninitialized collection

错误SQL代码:

declare 
 TYPE t_student_var IS TABLE OF VARCHAR2(100);
 
 v_tbl_name t_student_var;
begin
 select name into v_tbl_name(1) from t_student where gid = 1;
 select name into v_tbl_name(2) from t_student where gid = 2;
 select name into v_tbl_name(3) from t_student where gid = 3;
 dbms_output.put_line(v_tbl_name(1));
 dbms_output.put_line(v_tbl_name(2));
 dbms_output.put_line(v_tbl_name(3));
end;

问题分析:

Oracle自定义类型语法:

TYPE type_name IS TABLE OF element_type INDEX BY [BINARY_INTEGER | PLS_INTEGER | VARRAY2]; 其中:INDEX BY: 该语句的作用是使Number类型的下标自增长,,自动初始化,并分配空间,有了该语句,向表记录插入元素时,不需要显示初始化,也不需要通过extend分配空间。Binary_Integer 与 Pls_Integer 都是整型类型.

Binary_Integer类型变量值计算是由Oracle来执行,不会出现溢出,但是执行速度较慢,因为它是由Oracle模拟执行。而Pls_Integer的执行是由硬件即直接由CPU来运算,因而会出现溢出,但其执行速度较前者快许多。

通过上面的说明可以知道解决的办法有两个:

1、定义记录表类型时,要加上INDEX BY语句,修改之后如下:

declare 
 TYPE t_student_var IS TABLE OF VARCHAR2(100) INDEX BY BINARY_INTEGER;
 
 v_tbl_name t_student_var;
begin
 select name into v_tbl_name(1) from t_student where gid = 1;
 select name into v_tbl_name(2) from t_student where gid = 2;
 select name into v_tbl_name(3) from t_student where gid = 3;
 dbms_output.put_line(v_tbl_name(1));
 dbms_output.put_line(v_tbl_name(2));
 dbms_output.put_line(v_tbl_name(3));
end;

这种方式比较简易,建议使用这种方式.

2、初始化,并使用extend语句扩展空间,修改之后如下:

declare 
 TYPE t_student_var IS TABLE OF VARCHAR2(100);
 
 v_tbl_name t_student_var := t_student_var();--初始化
begin
 v_tbl_name.extend;--扩展空间
 select name into v_tbl_name(1) from t_student where gid = 1;
 v_tbl_name.extend;--扩展空间
 select name into v_tbl_name(2) from t_student where gid = 2;
 v_tbl_name.extend;--扩展空间
 select name into v_tbl_name(3) from t_student where gid = 3;
 dbms_output.put_line(v_tbl_name(1));
 dbms_output.put_line(v_tbl_name(2));
 dbms_output.put_line(v_tbl_name(3));
end;

另外,使用extend(n),一次性扩展n个空间,所以下面代码和上面的效果是一样的:

declare 
 TYPE t_student_var IS TABLE OF VARCHAR2(100);
 
 v_tbl_name t_student_var := t_student_var();--初始化
begin
 v_tbl_name.extend(3);--扩展3个空间
 select name into v_tbl_name(1) from t_student where gid = 1;
 select name into v_tbl_name(2) from t_student where gid = 2;
 select name into v_tbl_name(3) from t_student where gid = 3;
 dbms_output.put_line(v_tbl_name(1));
 dbms_output.put_line(v_tbl_name(2));
 dbms_output.put_line(v_tbl_name(3));
end

文档

ORA-06531:Referencetouninitializedcollection问题解决

ORA-06531:Referencetouninitializedcollection问题解决:ORA-06531:Reference to uninitialized collection 问题解决错误信息:ORA-06531:Reference to uninitialized collection错误SQL代码:declare TYPE t_student_var IS TABLE OF VARCHAR2(100); v_tbl_n
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top