关于sqlca.sqlerrd[2]

本文探讨了在SQL中,sqlca.sqlerrd[2]字段如何在执行DML操作(如execute, insert, update, delete)和游标操作(如open, fetch)时,记录处理的行数。在游标循环中,它用于跟踪每次fetch处理的行数,从而调整循环逻辑。例如,当BAT_NUM为50时,游标每次fetch和deal会根据sqlca.sqlerrd[2]更新处理状态。
摘要由CSDN通过智能技术生成

1.说明

sqlca.sqlerrd[2]当sql语句成功时,保存当前sql语句处理的行数。
对于execute,insert,update,delete,select into反映成功处理的函数。
在open语句执行时,sqlerrd[2]置为0,在fetch后增值。

2.项目举例

BAT_NUM为常量,假设为50

游标cursor1 

结构体STRUCT1,最大值设为BAT_NUM

第一次循环:

iFetched = 50-0=50

(之所以sqlca.sqlerd[2] 为50,是由于STRUCT1限制了最大条数BAT_NUM-50)

iDealed = 50

第二次循环

iFetch = 100-50=50

iDeal = 100

以此类推

while(iFetch == BAT_NUM)
{

        exec sql fetch cursor1 into STRUCT1.XX;

        iFetch = sqlca.sqlerrd[2] - iDeal;
        if(iFetch == 0)
              break;
        iDeal = sqlca.sqlerrd[2];
        for(i = 0 ; i < iFetch ; i++)
        {

        }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值