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;
  • 相关阅读:
    【转】大内高手—内存管理器
    [转]内存泄漏测试小工具 LeakDiag
    [转]内存泄漏测试小工具 LeakDiag
    (转)SplitContainer 控件(Windows 窗体)
    (转)c++内存分配优先使用内存池,而不是new,delete
    (转)C++内存池
    LeakDiag 使用注意
    Struts Validator验证器使用指南
    oracle JOB样例
    oralce杀session
  • 原文地址:https://www.cnblogs.com/dushan/p/5073229.html
Copyright © 2011-2022 走看看