zoukankan      html  css  js  c++  java
  • ORACLE存储过程中%TYPE和%ROWTYPE的区别

    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;
  • 相关阅读:
    HDU1542矩形面积并
    HDU5869树状数组+gcd预处理
    HDU5845 Best Division
    整体二分
    Lattice 的 Framebuffer IP核使用调试笔记之datasheet笔记
    DDR3详解(以Micron MT41J128M8 1Gb DDR3 SDRAM为例)
    ISD1700系列多段语音录放系列
    Lattice Diamond 学习之编译、检查和设置约束
    欧拉函数的几个性质及证明
    CF776B Sherlock and his girlfriend
  • 原文地址:https://www.cnblogs.com/dushan/p/5073229.html
Copyright © 2011-2022 走看看