最近在做一个项目,用JBuilder 2005和DB2 7.0开发。用QueryDataSet取DB2中Blob字段时遇到一个问题:QueryDataSet不能用getBinaryStream()的方 法取blob的数据,默认只能用getString()的方法,取出的string里面存放的是16进制流的字符串,把这个字符串转换成二进制流之后输出 到文件,却是乱码。
从网上找到资料,原来需要把两个字符转成一个字节码。代码如下:
//注意:此方法和getBytes的不同之处是,这里需要两个字符转成一个字节码。
private byte[] str2ByteArray(String str) {
int length = 0;
if (str.length() % 2 == 0)
length = str.length() / 2;
else
length = str.length() / 2 + 1;
byte[] result = new byte[length];
String s = "";
int j = 0;
for (int i = 0; i < str.length(); i += 2) {
if ((i + 2) < str.length()) {
s = str.substring(i, i + 2);
} else {
s = str.substring(i, str.length());
}
if (!s.equals("") && !s.equals("##")) {
byte b = new Integer(Integer.parseInt(s, 16)).byteValue();
result[j++] = b;
}
}
return result;
}
private byte[] str2ByteArray(String str) {
int length = 0;
if (str.length() % 2 == 0)
length = str.length() / 2;
else
length = str.length() / 2 + 1;
byte[] result = new byte[length];
String s = "";
int j = 0;
for (int i = 0; i < str.length(); i += 2) {
if ((i + 2) < str.length()) {
s = str.substring(i, i + 2);
} else {
s = str.substring(i, str.length());
}
if (!s.equals("") && !s.equals("##")) {
byte b = new Integer(Integer.parseInt(s, 16)).byteValue();
result[j++] = b;
}
}
return result;
}
将字符串转换之后,InputStream in = new ByteArrayInputStream(byte[]),然后就可以将InputStream输出到文件了。
本文介绍使用JBuilder2005与DB27.0进行项目开发时,如何正确处理Blob字段数据的问题。通过自定义方法将16进制字符串转换为二进制流,并最终保存为文件。

8590

被折叠的 条评论
为什么被折叠?



