免费注册 查看新帖 |

Chinaunix

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

IBM INFORMIX ODBC 的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-31 10:05 |只看该作者 |倒序浏览
最近写了一个通过ODBC 访问informix 的程序, 执行语句的时候发现程序直接退出, 并造成informix 数据库 down 了
并在程序目录下产生了一些文件 如 B8e17934  B8e17780 之类

程序在参数准备完成, 最后一次调用SQLParamData时, 收到一个SIGSEGV信号..
我绑定的两个参数类型是SQL_LONGVARBINARY (BLOB) 和 SQL_LONGVARCHAR(CLOB)
请各位大侠帮忙.

执行的代码如下:

int Execute(TCursor *prs)
{
    SQLRETURN   rc;
    IFXLobLocator *locp;

    /* execute the statement */
    rc = SQLExecute(prs->hstmt);
    if (CheckErr(SQL_HANDLE_STMT, prs->hstmt, rc) != 0)
    {
        printf("SQLExecute Error -- %s\n", DBGetLastError());
        return -1;
    }

    if (rc == SQL_NEED_DATA)
    {
        rc = SQLParamData(prs->hstmt, (SQLPOINTER *)&locp);
        if (CheckErr(SQL_HANDLE_STMT, prs->hstmt, rc) != 0)
        {
            printf("SQLParamData Error -- %s\n", DBGetLastError());
            SQLCancel(prs->hstmt);
            return -1;
        }

        while (rc == SQL_NEED_DATA)
        {
            if (locp->lobp == NULL || locp->loblen == 0)
                rc = SQLPutData(prs->hstmt, locp->lobp, SQL_NULL_DATA);
            else
                rc = SQLPutData(prs->hstmt, locp->lobp, locp->loblen);

            if (CheckErr(SQL_HANDLE_STMT, prs->hstmt, rc) != 0)
            {
                printf("SQLPutData Error -- %s\n", DBGetLastError());
                SQLCancel(prs->hstmt);
                return -1;
            }

            rc = SQLParamData(prs->hstmt, (SQLPOINTER *)&locp);
            if (CheckErr(SQL_HANDLE_STMT, prs->hstmt, rc) != 0)
            {
                printf("SQLParamData Error -- %s\n", DBGetLastError());
                SQLCancel(prs->hstmt);
                return -1;
            }
        }
    }
    return 0;
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP