您的位置:首页 > 数据库 > Oracle

ORACLE存储过程中%TYPE和%ROWTYPE的区别

2015-12-24 15:25 441 查看

ORACLE存储过程中%TYPE和%ROWTYPE的区别


在存储过程中%TYPE和%ROWTYPE常用来在PL/SQL中定义变量


因为
t_emp emp%rowtype
;这个语句的意思是 定义一个变量t_emp使其与EMP表具有一样的数据类型. 也就是说EMP表有哪里数据类型的字段,那么这个t_EMP变量也就能够存储什么类型的数据,而且大小范围也是一样的.(如VARCHAR2(20))


(一)使用%TYPE


PL/SQL中的变量用来存储在数据库表中的数据,所以变量和表中的列应该有相同的类型,例如按如下方式声明一个变量:

DECLARE  v_code varchar2(20)

但是如果v_code这一列的定义发生了变化,例如长度发生了变化,那么导致所有使用该列的PL/SQL代码全部都要修改

但是如果使用%TYPE属性而不是将变量类型硬性编码,代码如下:

DECLARE v_code oms_outbound.code%TYPE


通过使用%TYPE,变量v_code将和表oms_outbound的列code类型相同(可以理解为将二者绑定起来)


(二)使用%ROWTYPE


在PL/SQL中讲一个记录声明为具有相同类型的数据库行时,使用%ROWTYPE

代码如下:

DECLARE v_code oms_outbound%ROWTYPE


定义了一个记录,该记录中的字段与oms_outbound表中的列相对应

存储过程代码如下:

/** 重新同步签收状态*/

PROCEDURE SP_PUSH_SIGN_LOG IS

v_order VARCHAR2(50);

v_way_bill_code VARCHAR2(50);

v_log VARCHAR2(2000);

CURSOR c IS /**声明游标,表示多行记录,每一行结构与查询结果一致 */

SELECT ts.order_no FROM tmp_sign_order ts;

c_row c%ROWTYPE; /**使用rowtype */

BEGIN

FOR c_row IN c

LOOP

SELECT t.way_bill_code INTO v_way_bill_code FROM tms_order t WHERE t.code = c_row.order_no;

v_log := '{"sign":0,"desc":"","msg":"","orderCode":"'||c_row.order_no||'","expressCode":"'||v_way_bill_code||'"}';

INSERT INTO bis_sync_error_data_pool(id,req_buss_type,params,retry_times,creator_id,creator,created_time,last_operator_id,last_operator,last_operated_time,related_code)VALUES

(seq_bis_sync_error_data_pool.nextval,'SYNC_ORDER_SIGNED',v_log,0,'1','zhoujie',SYSDATE,'1','zhoujie',SYSDATE,'zhoujie');

END LOOP;

--SELECT FROM tms_order t WHERE t.

END SP_PUSH_SIGN_LOG;</code></pre>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: