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>
相关文章推荐
- Oracle杀死死锁进程
- oracle 10g升级到11g
- PGA资源的管理
- Oracle Dataguard的原理与基本配置
- Oracle TO_CHAR()和TO_DATA()函数日期和字符串互相转换
- Oracle使用并行建索引须要注意的问题
- Java对Oracle中Clob类型数据的读取和写入(转)
- java 读取Oracle的clob,blob转换为字符串
- oracle 11g用户名密码区分大小写
- Oracle如何实现跨库查询
- ORACLE字符集基础知识(NLS)
- 再论ORACLE的全球化支持(GLOBALIZATION)
- oracle之乘法口诀
- oracle自治事务
- oracle基础知识
- 在windows Server 2008 R2上安装oracle 12C 出现的问题以及解决方法
- Oracle trunc()函数的用法
- Oracle基础
- oracle的commit详解
- Oracle PLSQL 数组及 ROWTYPE的使…