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;

ORACLE存储过程中%TYPE和%ROWTYPE的区别的更多相关文章

  1. oracle存储过程中%type的含义

    转: oracle存储过程中%type的含义 2018-11-07 11:43:56 lizhi_ma 阅读数 1361更多 分类专栏: 数据库   版权声明:本文为博主原创文章,遵循CC 4.0 B ...

  2. Oracle存储过程中跳出循环的写法

    注:本文来源于: <  Oracle存储过程中跳出循环的写法   > Oracle存储过程中跳出循环的写法 记录exit和return的用法 1:exit用来跳出循环 loop IF V_ ...

  3. java 实现往oracle存储过程中传递array数组类型的参数

    注:本文来源于 <  java 实现往oracle存储过程中传递array数组类型的参数  >最近项目中遇到通过往存储过程传递数组参数的问题, 浪费了N多个小时,终于有点头绪. 具体的代码 ...

  4. Oracle存储过程中异常Exception的捕捉和处理

    Oracle存储过程中异常的捕捉和处理 CREATE OR REPLACE Procedure Proc_error_process ( v_IN in Varchar2, v_OUT Out Var ...

  5. Oracle存储过程中异步调用的实际操作步骤

    本文标签:Oracle存储过程 我们都知道在Oracle数据库的实际应用的过程中,我们经常把相关的业务处理逻辑,放在Oracle存储过程中,客户端以通过ADO来进行相关的调用  .而有些相关的业务逻辑 ...

  6. Python中type与Object的区别

    Python中type与Object的区别 在查看了Python的API后,总算明白了.现在总结如下: 先来看object的说明: Python中关于object的说明很少,甚至只有一句话: clas ...

  7. oracle存储过程中使用execute immediate执行sql报ora-01031权限不足的问题

    oracle存储过程中使用execute immediate执行sql报ora-01031权限不足的问题 学习了:http://blog.csdn.net/royzhang7/article/deta ...

  8. 在ORACLE存储过程中创建临时表

    在ORACLE存储过程中创建临时表 存储过程里不能直接使用DDL语句,所以只能使用动态SQL语句来执行 --ON COMMIT DELETE ROWS 说明临时表是事务指定,每次提交后ORACLE将截 ...

  9. ORACLE中%TYPE和%ROWTYPE的使用

     1 %TYPE说明 为了使一个变量的数据类型与还有一个已经定义了的变量(尤其是表的某一列)的数据类型相一致,Oracle提供了%TYPE定义方式.当被參照的那个变量的数据类型改变了之后,这个新定 ...

随机推荐

  1. iPhone X手机投屏电脑无线连接教程

    iPhone X手机是一款非常有气场的手机,独特的设计,展现手机的独特魅力,手机外观让人一眼就爱上,手感也是超级的舒适,真的是堪称完美,但是iPhone X手机投屏电脑怎么无线连接呢? 使用工具: 电 ...

  2. iOS中时间与时间戳的相互转化

    //获取当前系统时间的时间戳 #pragma mark - 获取当前时间的 时间戳 +(NSInteger)getNowTimestamp{ NSDateFormatter *formatter = ...

  3. JMeter java.net.URISyntaxException:Illegalcharacterinquery解决方案

    java.net.URISyntaxException: Illegal character in query解决方案   by:授客 QQ:1033553122 测试环境 apache-jmeter ...

  4. AndroBench手机性能测试

    AndroBench是一个基准测试应用程序,可以衡量你的Android设备的存储性能. AndroBench提供两种方式,第一种可以快速与其他设备的存储进行比较. 第二种 SQLite可以查询数据库表 ...

  5. (网页)angularJs中怎么模拟jQuery中的this?(转)

    转载自mini_fan博客园: 今天想在Angular项目中使用jQuery的this功能,发现undefined.代码如下: HTML部分: <p ng-click="testCli ...

  6. ntohs, ntohl, htons,htonl对比

    ntohs =net to host short int 16位htons=host to net short int 16位ntohl =net to host long int 32位htonl= ...

  7. [20181122]模拟ORA-08103错误.txt

    [20181122]模拟ORA-08103错误.txt $ oerr ora 810308103, 00000, "object no longer exists"// *Caus ...

  8. MySQl ifnull()和substr()

    SUBSTR(str,pos,len) substr用来截取字符串: str 被截取的字符串 pos 开始位置 len 长度 举个例子: substr('abc',1,2)='ab' IFNULL(e ...

  9. c/c++ 数组 数组的引用,指针数组的引用

    c/c++ 数组 知识点 1,数组的声明和初始化,对应代码里的test1和test2 2,char数组,对应代码里的test3 3,数组不可以拷贝和复制,对应代码里的test4 4,指针数组, 数组的 ...

  10. mac os 10.12 Sierra 连接 惠普 M1136 MFP 打印机,通过 samba 协议,安装驱动,连接打印机

    参考链接: https://support.hp.com/hk-zh/product/hp-zbook-17-g3-mobile-workstation/8693765/document/c04530 ...