pl/sql 如何将查询结果集放在数组中 select * from tablename结果为42列,4行。在pl/sql中定义了一个二维数组([4][42])NA T_t_col,如何将将结果插入到二维数组NA中?语法是怎样的,要用到游标吗? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 pl/sql能这样定义二维数组吗?建议用pl/sql表,即索引表(index-by tables)。参考如下代码:declare type table_type is table of emp%rowtype index by binary_integer; l_table_type table_type; i_index integer := 0; begin for v_cur in (select * from emp) loop i_index := i_index + 1; l_table_type(i_index) := v_cur; dbms_output.put_line('i_index:' || i_index || ',empno.:' || l_table_type(i_index).empno); end loop;end; 转篇文章你看下因为在PL/SQL 中并没有数组. 这是偶查资料找的范例和自己写的范例来解释如何在PL/SQL 中使用数组. 也许很多人已知道, 不过就是让不知道的朋友们了解一下吧。---------------------- 单维数组------------------------DECLARETYPE emp_ssn_array IS TABLE OF NUMBERINDEX BY BINARY_INTEGER;best_employees emp_ssn_array;worst_employees emp_ssn_array;BEGINbest_employees(1) := '123456';best_employees(2) := '888888';worst_employees(1) := '222222';worst_employees(2) := '666666';FOR i IN 1..best_employees.count LOOPDBMS_OUTPUT.PUT_LINE('i='|| i || ', best_employees= ' ||best_employees(i)|| ', worst_employees= ' ||worst_employees(i));END LOOP;END;---------------------- 多维数组------------------------DECLARETYPE emp_type IS RECORD( emp_id employee_table.emp_id%TYPE,emp_name employee_table.emp_name%TYPE,emp_gender employee_table.emp_gender%TYPE );TYPE emp_type_array IS TABLE OFemp_type INDEX BY BINARY_INTEGER;emp_rec_array emp_type_array;emp_rec emp_type;BEGINemp_rec.emp_id := 300000000;emp_rec.emp_name := 'Barbara';emp_rec.emp_gender := 'Female';emp_rec_array(1) := emp_rec;emp_rec.emp_id := 300000008;emp_rec.emp_name := 'Rick';emp_rec.emp_gender := 'Male';emp_rec_array(2) := emp_rec;FOR i IN 1..emp_rec_array.count LOOPDBMS_OUTPUT.PUT_LINE('i='||i||', emp_id ='||emp_rec_array(i).emp_id||', emp_name ='||emp_rec_array(i).emp_name||', emp_gender = '||emp_rec_array(i).emp_gender);END LOOP;END;-------------- Result --------------i=1, emp_id =300000000, emp_name =Barbara, emp_gender = Femalei=2, emp_id =300000008, emp_name =Rick, emp_gender = Male注:在PL/SQL 中是没有数组(Array) 概念的. 但是如果程序员想用Array 的话, 就得变通一下, 用TYPE 和Table of Record 来代替多维数组, 一样挺好用的。emp_type 就好象一个table 中的一条record 一样, 里面有id, name,gender等。emp_type_array 象个table, 里面含有一条条这样的record (emp_type),就象多维数组一样。 游标问题-没有输出? ORA-25401: 无法继续读取 请问? 请教:在oracle 下如何删除表? 求oracle8i中文版有效下载地址,百分只送一人 如何全备份一个oracle 数据 库 大家好!我是南京的,想找人合租房,不知道谁有合适的房子合租,谢谢!!地址是可以坐80路或者82路车,或者在建邺路,白下路附近也可以! oledbdatareader的问题,急啊 大家看看这个增长率的sql怎么写? oracle存储过程调用奇葩 oracle用sysdba身份登陆疑问 怎么做数据库登录用户的查询?
参考如下代码:declare
type table_type is table of emp%rowtype
index by binary_integer;
l_table_type table_type;
i_index integer := 0;
begin
for v_cur in (select * from emp) loop
i_index := i_index + 1;
l_table_type(i_index) := v_cur;
dbms_output.put_line('i_index:' || i_index || ',empno.:' || l_table_type(i_index).empno);
end loop;
end;
DECLARE
TYPE emp_ssn_array IS TABLE OF NUMBER
INDEX BY BINARY_INTEGER;best_employees emp_ssn_array;
worst_employees emp_ssn_array;BEGIN
best_employees(1) := '123456';
best_employees(2) := '888888';worst_employees(1) := '222222';
worst_employees(2) := '666666';FOR i IN 1..best_employees.count LOOP
DBMS_OUTPUT.PUT_LINE('i='|| i || ', best_employees= ' ||best_employees(i)
|| ', worst_employees= ' ||worst_employees(i));
END LOOP;END;---------------------- 多维数组------------------------
DECLARETYPE emp_type IS RECORD
( emp_id employee_table.emp_id%TYPE,
emp_name employee_table.emp_name%TYPE,
emp_gender employee_table.emp_gender%TYPE );TYPE emp_type_array IS TABLE OF
emp_type INDEX BY BINARY_INTEGER;emp_rec_array emp_type_array;
emp_rec emp_type;BEGIN
emp_rec.emp_id := 300000000;
emp_rec.emp_name := 'Barbara';
emp_rec.emp_gender := 'Female';emp_rec_array(1) := emp_rec;emp_rec.emp_id := 300000008;
emp_rec.emp_name := 'Rick';
emp_rec.emp_gender := 'Male';emp_rec_array(2) := emp_rec;FOR i IN 1..emp_rec_array.count LOOP
DBMS_OUTPUT.PUT_LINE('i='||i
||', emp_id ='||emp_rec_array(i).emp_id
||', emp_name ='||emp_rec_array(i).emp_name
||', emp_gender = '||emp_rec_array(i).emp_gender);
END LOOP;END;
-------------- Result --------------
i=1, emp_id =300000000, emp_name =Barbara, emp_gender = Female
i=2, emp_id =300000008, emp_name =Rick, emp_gender = Male注:在PL/SQL 中是没有数组(Array) 概念的. 但是如果程序员想用Array 的话, 就得变通一下, 用TYPE 和Table of Record 来代替多维数组, 一样挺好用的。
emp_type 就好象一个table 中的一条record 一样, 里面有id, name,gender等。emp_type_array 象个table, 里面含有一条条这样的record (emp_type),就象多维数组一样。