免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2392 | 回复: 0
打印 上一主题 下一主题

proc中open游标的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-06-02 21:41 |只看该作者 |倒序浏览
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] = '\0';
                mesData.arr[mesData.len] = '\0';
                matNo.arr[matNo.len] = '\0';
                mesDate.arr[mesDate.len] = '\0';
               
                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;
也没有错误返回。 帮忙分析一下 谢谢。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP