1

次のクエリがあります (列ログは CLOB 型です):

UPDATE table SET log=? where id=?

上記のクエリは、setAsciiStream メソッドを使用して 4000 文字を超える値をログ列に入れる場合に正常に機能します。

しかし、値を置き換える代わりに追加したいので、クエリは次のようになります。

UPDATE table SET log=log||?||chr(10) where id=?

上記のクエリは機能しなくなり、次のエラーが発生します。

java.sql.SQLException: ORA-01461: can bind a LONG value only for insert into a LONG column
4

2 に答える 2

2

BLOB は SQL から変更できないため (NULL に設定する以外は)、追加するには、最初に BLOB をダウンロードし、ローカルで連結して、結果を再度アップロードする必要があります。

通常の解決策は、共通キーと、行の順序を DB に指示するシーケンスを使用して、複数のレコードをデータベースに書き込むことです。

于 2009-03-24T16:33:23.410 に答える
2

PL/SQL ブロックを使用して必要なことを行う必要があるように思えます。id1のエントリがあると仮定すると、次のように機能します。

import oracle.jdbc.OracleDriver;
import java.sql.*;
import java.io.ByteArrayInputStream;

public class JDBCTest {

    // How much test data to generate.
    public static final int SIZE = 8192;

    public static void main(String[] args) throws Exception {

        // Generate some test data.
        byte[] data = new byte[SIZE];
        for (int i = 0; i < SIZE; ++i) {
            data[i] = (byte) (64 + (i % 32));
        }

        ByteArrayInputStream stream = new ByteArrayInputStream(data);

        DriverManager.registerDriver(new OracleDriver());
        Connection c = DriverManager.getConnection(
            "jdbc:oracle:thin:@some_database", "user", "password");

        String sql =
            "DECLARE\n" +
            "  l_line    CLOB;\n" +
            "BEGIN\n" +
            "  l_line := ?;\n" +
            "  UPDATE table SET log = log || l_line || CHR(10) WHERE id = ?;\n" +
            "END;\n";

        PreparedStatement stmt = c.prepareStatement(sql);
        stmt.setAsciiStream(1, stream, SIZE);
        stmt.setInt(2, 1);
        stmt.execute();
        stmt.close();

        c.commit();

        c.close();
    }
}
于 2009-03-28T22:44:51.020 に答える