oracle存储过程一个陷阱

本文探讨了Oracle存储过程中变量名与表字段名相同导致的问题。通过一个具体例子说明了当两者名称一致时,约束将不起作用的情况,并提出了命名建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1:如下oracle存储过程(同事发现):

//*************************************************************************************//

create or replace procedure test is
        strTaskID varchar2(50):='123321';
        CURSOR Cursortt is SELECT * FROM T_FCVSTASK where strTaskID = strTaskID and 1=1;
        ccclip  Cursortt%rowtype; 
begin   
        open Cursortt;
         loop
            fetch Cursortt into ccclip;
            exit when Cursortt%notfound;
            strTaskID := '123';
         end loop;
end test;

//*************************************************************************************//

当定义的变量名与表中字段名一样时,约束不起作用(红色标记处);

结论: 此问题确实存在, 但是平时我们因该按oracle常规写比如以上变量:v_strTaskId 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值