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. 章节二、1-java概述-数据类型

    一.数据类型 1.基本数据类型 a.数值型 1.整数:byte(1个字节=8位) min:-128 max:127 default:0 .short(2个字节=16位) min:-32768 max: ...

  2. codeforces 2B The least round way(DP+数学)

    The least round way 题目链接:http://codeforces.com/contest/2/problem/B ——每天在线,欢迎留言谈论.PS.本题有什么想法.建议.疑问 欢迎 ...

  3. Linux 中提高的 SSH 的安全性

    SSH 是远程登录 Linux 服务器的最常见的方式.且 SSH 登录的时候要验证的,相对来讲会比较安全.那只是相对,下面会介绍一些方式提高 SSH 的安全性 SSH 的验证 而SSH 登录时有两种验 ...

  4. mysql练习----SUM and COUNT/zh图(二)

    世界国家概况 GROUP BY 和 HAVING 通过包括一个GROUP BY子句功能, SUM并将COUNT 其应用于共享值的项目组.当你指定 GROUP BY continent 结果是每个不同的 ...

  5. Java读取.properties配置文件

    一.介绍 Properties文件在Java中主要为配置文件,文件类型为:.properties,格式为文本文件,内容格式为"键=值" 二.读取 这里我采用的是getResourc ...

  6. Elasticsearch深入搜索之结构化搜索及JavaAPI的使用

    一.Es中创建索引 1.创建索引: 在之前的Es插件的安装和使用中说到创建索引自定义分词器和创建type,当时是分开写的,其实创建索引时也可以创建type,并指定分词器. PUT /my_index ...

  7. c/c++ allocator 使用

    allocator 使用 作用:只开辟空间,不调用构造函数 操作一览表 allocator<T> a 定义一个名为a的allocator对象,它可以为类型为T的对象分配内存 a.alloc ...

  8. esxi网络中虚拟机的相关操作

    一个虚拟机的克隆就是原始虚拟机全部状态的一个备份或镜像.克隆的过程不影响原始虚拟机.而快照指的是虚拟磁盘在某一特定时间点的副本.执行快照将保留虚拟机的状况和数据. 一.实验拓扑图: 目标:克隆虚拟机, ...

  9. LeetCode算法题-Majority Element(Java实现)

    这是悦乐书的第181次更新,第183篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第40题(顺位题号是169).给定大小为n的数组,找到数组中出现次数超过n/2的元素.假 ...

  10. intellij IDEA导入java源码

    第一步: 从安装的jdk目录中找到src.zip文件, 这里是java源码的压缩包 第二步: 打开IDEA, 随便一个java相关项目,打开右上角的project structure 第三步: 点开源 ...