proc中open游标的问题

发布于 2022-08-31 04:36:53 字数 5450 浏览 10 评论 0

int queryDB_TB_FRA100(TABLE_ITEM *pTable_item_out)
{
        int nCount = 0;
       
        EXEC SQL BEGIN DECLARE SECTION;
        VARCHAR sqlstr[512];
        VARCHAR mesID[32+1];
        VARCHAR mesData[4999+1];
        VARCHAR mesDate[14+1];
        VARCHAR matNo[32+1];
        VARCHAR test[36];
        EXEC SQL END DECLARE SECTION;
       
        if (sqlca.sqlcode != 0)
        {
                etsDebug(0, "数据库关闭sqlca.sqlcode1[%d]", sqlca.sqlcode);
                return -1;
        }
       
        /*执行sql语句*/
       
        EXEC SQL DECLARE t_cursor CURSOR FOR SELECT Msg_id,MAT_no,Remark,crt_dtime FROM TB_FRA100 WHERE Flag = 0 ORDER BY Crt_dtime ASC;
       
               
        EXEC SQL OPEN t_cursor;
       
        if (sqlca.sqlcode != 0)
        {
                etsDebug(0, "数据库关闭sqlca.sqlcode3[%d]", sqlca.sqlcode);
                EXEC SQL CLOSE t_cursor;
                return -1;
        }
       
        while (1)
        {
                memset(mesID.arr, 0, sizeof(mesID.arr));
                mesID.len = 0;
                memset(mesData.arr, 0, sizeof(mesData.arr));
                mesData.len = 0;
                memset(matNo.arr, 0, sizeof(matNo.arr));
                matNo.len = 0;
                memset(mesDate.arr, 0, sizeof(mesDate.arr));
                matNo.len = 0;
               
                EXEC SQL FETCH t_cursor INTO :mesID, :matNo, :mesData, :mesDate;
               
                if (sqlca.sqlcode == 1403)
                {
                        break;
                }
               
                if (sqlca.sqlcode < 0)
                {
                        etsDebug(0, "数据库关闭sqlca.sqlcode5[%d]", sqlca.sqlcode);
                        EXEC SQL CLOSE t_cursor;
                        return -1;
                       
                }
               
                mesID.arr[mesID.len] = '';
                mesData.arr[mesData.len] = '';
                matNo.arr[matNo.len] = '';
                mesDate.arr[mesDate.len] = '';
               
                strncpy(pTable_item_out[nCount].mesID, mesID.arr, 32);
                strncpy(pTable_item_out[nCount].mesData, mesData.arr, 4999);
                strncpy(pTable_item_out[nCount].matNo, matNo.arr, 32);
                strncpy(pTable_item_out[nCount].mesDate, mesDate.arr, 14);
               
               
                ++nCount;
        }
        EXEC SQL CLOSE t_cursor;
       
        return nCount;
}

此段程序 运行一段时间后就停在EXEC SQL OPEN t_cursor;
也没有错误返回。 帮忙分析一下 谢谢。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文