【发布时间】:2011-03-06 17:31:30
【问题描述】:
我想从用 Java 编写的 DB2 存储过程中以 Blob 形式返回一些数据。
这是在 DB2 服务器上生成过程的代码:
CREATE PROCEDURE CLUB.P_CLUB_GET_BACKUP ( IN CLUBID INTEGER,
IN BNR INTEGER,
OUT BACKUP BLOB(50000000) )
NO SQL
NOT DETERMINISTIC
LANGUAGE Java
EXTERNAL NAME 'P_CLUB_GET_BACKUP:ch.swissasp.vvv.procedures.P_GET_BACKUP1.p_GET_BACKUP1'
FENCED
THREADSAFE
PARAMETER STYLE JAVA
而对应的Java代码是这样的:
/**
* SQLJ Stored Procedure P_GET_BACKUP
* @param clubID
* @param backupID
* @param Backup
*/
package ch.swissasp.vvv.procedures;
import java.io.File;
import java.io.FileInputStream;
import java.sql.SQLException;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;
public class P_GET_BACKUP1
{
public static void p_GET_BACKUP1(int clubID, int backupNr, java.sql.Blob[] backup)
throws SQLException,
Exception
{
// create blob and return as output parameter 'backup'
}
}
我现在需要的是某种方法从存储过程中生成的一些二进制数据生成 Blob(因此 Blob 不是来自查询,而是读取驻留在数据库服务器上的数据),然后返回这个blob 作为输出参数“备份”。问题是,我不知道如何动态创建 blob,因为 java.sql.Blob 本身就是一个接口。我可以像这样使用虚拟 SQL 创建一个 blob:
// create a blob the complicated way...
Connection con = DriverManager.getConnection("jdbc:default:connection");
con.setReadOnly(true);
PreparedStatement stmt = con.prepareStatement("VALUES (Cast(? AS Blob))");
stmt.setBytes(1, new byte[0]);
ResultSet rs = stmt.executeQuery();
rs.next();
Blob blob = rs.getBlob(1);
rs.close();
然后像这样使用它:
OutputStream out = blob.setBinaryStream(1L); // get output stream to blob
// code to write the data to output stream
out.close(); // close blob
backup[0] = blob; // set output param
但我最好能够将所有 SQL 代码替换为以下内容:
java.sql.Blob blob = new DB2Blob(); // dynamically allocate blob
如果存在在 DB2 中动态创建 blob 的工具,有什么想法吗?
【问题讨论】:
-
这个聚会很晚了,但你不能创建一个 SerialBlob 并返回它吗?它实现了 blob 接口并有一个 byte[] 构造函数。 docs.oracle.com/javase/7/docs/api/javax/sql/rowset/serial/…
-
这听起来很有希望。如果我有时间会测试。
标签: sql stored-procedures jdbc db2 blob