1.简述:
%rowtype表示该类型为“行数据类型”,存储的是一行数据,一行数据里可以有多列,类似于表里的一行数据,也可以是游标里的一行数据。
2.用法:
vs_row1 表%rowtype;
vs_row2 游标%rowtype;
3.示例:
CREATE OR REPLACE
PROCEDURE test_rowtype(V_PARAM1 VARCHAR2,V_PARAM2 VARCHAR2)
AS
BEGIN
DECLARE
cursor c_msg IS
SELECT A00,T0101,T0102,T0104,T0110 FROM TAL_A01 WHERE ROWNUM < 10;
c_row c_msg%rowtype;
v_result varchar2(500);
BEGIN
FOR c_row IN c_msg loop
v_result:=c_row.T0101||':'||V_PARAM1||'/'||V_PARAM2;
dbms_output.put_line(v_result);
END loop;
END;
END;
/
4.执行结果:
5.注意事项:
5.1报错:
navicate执行上述sql报以下错(打开错误的存储过程,可看到,sql并未执行完):
[Err] ORA-24344: success with compilation error
5.2解决:
用sqlplus进入的sql窗口执行,可执行完全