Oracle存储过程中%rowtype用法(游标简单示例)

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.执行结果:

Oracle存储过程中%rowtype用法(游标简单示例)_第1张图片

5.注意事项:

5.1报错:

navicate执行上述sql报以下错(打开错误的存储过程,可看到,sql并未执行完):
[Err] ORA-24344: success with compilation error

5.2解决:

用sqlplus进入的sql窗口执行,可执行完全

你可能感兴趣的:(Oracle)