达梦或者Oracle数据库,BLOB字段入库问题
BLOB字段用UPDATA或者INSERT into存储十六进制的数字串时,执行提示:执行失败(语句1)字符串截断,串长3万1时还可以插入,大于3万2,3左右就报错了。十六进制数据段超长入库解决,之前我用的是HEXTORAW(’’)赋值,Oracle是可以正常入库的,但是达梦就不行,所以找了很久,终于找到一个解决办法。替换方法如下:DECLAREVBLOBBLOB;BEGINdbms_lob.cr
·
BLOB字段用UPDATA或者INSERT into存储十六进制的数字串时,执行提示:执行失败(语句1)字符串截断,串长3万1时还可以插入,大于3万2,3左右就报错了。
十六进制数据段超长入库解决,之前我用的是HEXTORAW(’’)赋值,Oracle是可以正常入库的,但是达梦就不行,所以找了很久,终于找到一个解决办法。
替换方法如下:
DECLARE
VBLOB BLOB;
BEGIN
dbms_lob.createtemporary(VBLOB, FALSE);
dbms_lob.append(VBLOB, HEXTORAW('0EC1D7FA6B411DA58149'));
...
dbms_lob.append(VBLOB, HEXTORAW('0EC1D7FA6B411DA58149'));
UPDATE MyTable
SET blobData = VBLOB
WHERE ID = 32767;
END;
该解决办法引用出处:Oracle 10:使用HEXTORAW填充Blob数据
更多推荐
已为社区贡献1条内容
所有评论(0)