%TYPE和%ROWTYPE

本文详细介绍了PL/SQL中%TYPE和%ROWTYPE的区别及应用场景。%TYPE用于定义与表中某一列相同类型的变量,而%ROWTYPE则用于创建与表结构完全相同的记录类型。使用这两种类型可以有效降低代码维护成本并实现表结构的自适应变更。

%TYPE和%ROWTYPE有什么不同    

熟悉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;    /

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值