向DB2 blob追加数据



在我的DB2数据库中,我有一个Blob表:

CREATE TABLE FILE_STORAGE (
    FILE_STORAGE_ID integer,
    DATA blob(2147483647),
    CONSTRAINT PK_FILE_STORAGE PRIMARY KEY (FILE_STORAGE_ID));

使用db2jcc JDBC驱动程序(db2jcc4-9.7.jar),我可以毫无问题地读写这个表中的数据。

现在我需要能够将数据追加到现有行,但是DB2给出了神秘的错误

Invalid operation: setBinaryStream is not allowed on a locator or a reference. ERRORCODE=-4474, SQLSTATE=null

我使用以下代码来附加我的数据:

String selectQuery = "SELECT DATA FROM FILE_STORAGE WHERE FILE_STORAGE_ID = ?";
try (PreparedStatement ps = conn.prepareStatement(selectQuery, ResultSet.TYPE_FORWARD_ONLY, ResultSet.CONCUR_UPDATABLE)) {
    ps.setInt(1, fileStorageID);
    try (ResultSet rs = ps.executeQuery()) {
        if (rs.next()) {
            Blob existing = rs.getBlob(1);
            try {
                // The following line throws the exception:
                try (OutputStream output = existing.setBinaryStream(existing.length() + 1)) {
                    // append the new data to the output:
                    writeData(output);
                } catch (IOException e) {
                    throw new IllegalStateException("Error writing output stream to blob", e);
                }
                rs.updateBlob(1, existing);
                rs.updateRow();
            } finally {
                existing.free();
            }
        } else {
            throw new IllegalStateException("No row found for file storage ID: " + fileStorageID);
        }
    }
}

我的代码将OutputStream中建议的方法用于DB2数据库表的BLOB列。似乎还有其他人也有同样的问题:使用lob定位器更新lob列。

作为解决方案,我目前将所有现有数据读入内存,将新数据附加到内存中,然后将完整数据写回blob。这是有效的,但是速度很慢,如果blob中有更多的数据,显然需要更长的时间,每次更新都会变慢。

我确实需要使用Java来更新数据,但除了从JVM切换之外,我很乐意尝试任何可能的替代方案,我只需要以某种方式附加数据。

提前感谢任何想法!

如果您只需要将数据附加到BLOB列的末尾,而不想将整个值读取到程序中,那么简单的UPDATE语句将更快,更直接。

您的Java程序可以通过executeUpdate()运行如下内容:

UPDATE file_storage SET data = data || BLOB(?) WHERE file_storage_id = ?

此参数标记将由setBlob(1, dataToAppend)setInt(2, fileStorageID)填充。

最新更新