У меня есть объект java.sql.Clob, который я заполняю из запроса Oracle, а затем мне нужно вставить это поле в таблицу DB2 (также столбец Clob). Итак, в моем классе sqlj я создал тип java.sql.Clob и установил значение с результатом выбора Oracle (также java.sql.Clob). Длина Clob, которую я пытаюсь вставить, составляет около 2,5 МБ или dbms_lob.getlength возвращает 2500012.
Когда SQLJ выполняется, он выдает исключение:
COM.ibm.db2.jdbc.DB2Exception: [IBM][CLI Driver][DB2] SQL0433N Значение "" слишком длинное. SQLSTATE=22001
Я использую версию DB2: Сервер базы данных = DB2 OS/390 8.1.0.
Версия Oracle — Oracle Database 10g Enterprise Edition Release 10.2.0.5.0 — 64bit.
У вас есть идеи, почему выдается эта ошибка? Я искал документацию IBM, и предполагается использовать объект java.sql.Clob для вставки в столбец clob DB2...
«Входные параметры для столбцов CLOB Для параметров IN для столбцов CLOB или параметров INOUT, которые используются для ввода в столбцы CLOB, можно использовать один из следующих методов: Используйте входную переменную java.sql.Clob, которая точно соответствует столбец CLOB: cstmt.setClob(parmIndex, clobData);..."