免费注册 查看新帖 |

Chinaunix

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

DB2 使用C语言插入二进制数据到BLOB字段 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-08-03 17:02 |只看该作者 |倒序浏览
请问如何把一段报文(中间有0x00)插入到数据库表的BLOB类型的字段中,原来是方式是:
EXEC SQL BEGIN DECLARE SECTION;
    char blobMsg[100];
    SQL TYPE IS BLOB_LOCATOR blobMsg;
EXEC SQL END DECLARE SECTION;
EXEC SQL include sqlca;
EXEC SQL include sqlda;

int testBlob()
{
    memset(&blobMsg, 0, sizeof(blobMsg));
    blobMsg[0] = 0x30;
    blobMsg[1] = 0x30;
    blobMsg[2] = 0x00;  
    blobMsg[3] = 0x30;
    blobMsg[4] = 0x30;
    ......
   
    /*转换为BLOB类型*/
    EXEC SQL VALUES(BLOB(:blobMsg)) INTO :blobMsg;
    EXEC SQL INSERT INTO TBL_TEST_BLOB VALUES(:blobMsg);
}

表只有一个BLOB字段,这样数据是可以插入,但是从blobMsg[2]后面的数据就没保存进去,相当于遇到0x00就被截断了,请高手解答。
或者有类似经历的大侠分享下经验,谢谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP