熟悉PL/SQL的同志都知道,%type和%rowtype常用来在PL/SQL中定义变量.
%type和%rowtype都是在database中定义的类型,使用%type和%rowtype的好处是
1)减少PL/SQL代码的维护成本
2)自适应表结构的变化[比如字段的长度,精度发生变化]
%TYPE %TYPE用来声明一个变量和指定表的column一样的数据类型,比如 DECLARE v_EmpName emp.ename%TYPE; BEGIN SELECT ename INTO v_EmpName FROM emp WHERE ROWNUM = 1; DBMS_OUTPUT.PUT_LINE('Name = ' || v_EmpName); END; / %ROWTYPE %ROWTYPE用来声明一个和表中记录一样的record.如 DECLARE v_emp emp%ROWTYPE; BEGIN v_emp.empno := 10; v_emp.ename := 'XXXXXXX'; END; / DECLARE v_EmpRecord emp%ROWTYPE; BEGIN SELECT * INTO v_EmpRecord FROM emp WHERE ROWNUM = 1; DBMS_OUTPUT.PUT_LINE('Name = ' || v_EmpRecord.ename); DBMS_OUTPUT.PUT_LINE('Salary = ' || v_EmpRecord.sal); END;