请问存储过程中的%type是什么意思啊

如题所述

CREATE OR REPLACE PROCEDURE XXX
(
iID IN MY_TABLE.ID%TYPE
)
IS
BEGIN
END XXX;

说明:
iID IN MY_TABLE.ID%TYPE
iID参数的数据类型跟MY_TABLE表的ID字段类型一样,这样,你修改这个表的ID字段类型,就不用改存储过程了。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2009-08-19
oracle的%TYPE简介 2007-09-14 17:49 %TYPE属性 在PL/SQL中可以将变量和常量声明为内建或用户定义的数据类型,以引用一个列名,同时继承他的数据类型和大小。这种动态赋值方法是非常有用的,比如变量引用的列的数据类型和大小改变了,如果使用了%TYPE,那么用户就不必修改代码,否则就必须修改代码。
例: v_empno SCOTT.EMP.EMPNO%TYPE; v_salary EMP.SALARY%TYPE; 不但列名可以使用%TYPE,而且变量、游标、记录,或声明的常量都可以使用%TYPE。这对于定义相同数据类型的变量非常有用。
DELCARE V_A NUMBER(5):=10; V_B V_A%TYPE:=15; V_C V_A%TYPE;
BEGIN DBMS_OUTPUT.PUT_LINE ('V_A='||V_A||'V_B='||V_B||'V_C='||V_C);
END
SQL>/ V_A=10 V_B=15 V_C= PL/SQL procedure successfully completed.
SQL>

以上,希望对你有所帮助
相似回答