我需要从数组中删除元素。我试图使用array.delete(n)函数,但它删除标识符n的所有元素。如何删除确切的元素n?pl/sql从数组中删除元素
例如,如果阵列是1 2 3 4 5,并且n = 3,删除后它应该看起来像以下1 2 4 5
我迄今代码:
DECLARE
/* declare type array */
TYPE number_index_by_number IS TABLE OF number INDEX BY binary_integer;
v_n NUMBER := &sv_n;
v_m NUMBER := &sv_m;
v_min Number;
v_tmp Number;
v_array number_index_by_number;
v_sorted_array number_index_by_number;
begin
for i in 1..v_n
loop
v_array(i) := dbms_random.value(1,1000);
end loop;
for j in v_array.first..v_array.last
loop
DBMS_OUTPUT.put_line('v_array('||j||') :'||v_array(j));
end loop;
<<i_loop>> for i in 1..v_m
loop
/*set first array value to variable min*/
v_min := v_array(1);
v_tmp := 1;
<<j_loop>> for j in v_array.first..v_array.last
loop
DBMS_OUTPUT.put_line('v_array('||j||') :'||v_array(j));
if (v_min > v_array(j)) THEN
begin
v_min := v_array(j);
v_tmp := j;
DBMS_OUTPUT.put_line(j);
end;
end if;
end loop;
/*problem is in at this line*/
v_array.delete(v_tmp);
v_sorted_array(i) := v_min;
end loop;
for i in v_sorted_array.first..v_sorted_array.last
loop
DBMS_OUTPUT.put_line('v_sorted_array('||i||') :'||v_sorted_array(i));
end loop;
end;
你有什么症状一次性删除v_array? – Sebas 2013-03-09 19:08:32
它不会一次全部删除。它的作用就像例如。如果声明的数组是1 2 3 4 5,且n = 2,则在array.delete(n)数组仅包含两个元素之后。 1和2 – kuldarim 2013-03-09 19:13:54
,但它对你的算法有意义。问题是什么时候发生的?我的意思是,只要打开一个匿名块并尝试一下,就会发现它工作正常。我认为你的算法是问题。 http://docs.oracle.com/cd/B19306_01/appdev.102/b14261/collection_method.htm – Sebas 2013-03-09 19:20:33