[
https://issues.apache.org/jira/browse/DERBY-6214?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Kathey Marsden updated DERBY-6214:
----------------------------------
Attachment: derby.log
Derby6214.java
Derby6214_setup.sql
Here is a revised reproduction which separates out the setup sql from the java.
Commented out in the java program is a workaround which is to use setString
rather than setObject.
// Work around. setString works.
//ps.setString(1,"Modified CLOB value 2!!!!!!!!!!"); //2005);
To run:
java org.apace.derby.drda.NetworkServerControl start &
java org.apache.derby.tools.ij Derby6214_setup.sql
$java Derby6214
Exception in thread "main" org.apache.derby.client.am.BatchUpdateException:
Non-atomic batch failure. The batch was sub
mitted, but at least one exception occurred on an individual member of the
batch. Use getNextException() to retrieve the
exceptions for specific batched elements.
at org.apache.derby.client.am.Agent.endBatchedReadChain(Agent.java:270)
at
org.apache.derby.client.am.PreparedStatement.executeBatchRequestX(PreparedStatement.java:2359)
at
org.apache.derby.client.am.PreparedStatement.executeBatchX(PreparedStatement.java:2192)
at
org.apache.derby.client.am.PreparedStatement.executeBatch(PreparedStatement.java:1651)
at Derby6214.main(Derby6214.java:29)
Caused by: org.apache.derby.client.am.SqlException: Error for batch element #0:
An unexpected exception was thrown
at
org.apache.derby.client.am.Statement.completeExecute(Statement.java:1604)
at
org.apache.derby.client.net.NetStatementReply.parseEXCSQLSTTreply(NetStatementReply.java:322)
at
org.apache.derby.client.net.NetStatementReply.readExecute(NetStatementReply.java:71)
at
org.apache.derby.client.net.StatementReply.readExecute(StatementReply.java:55)
at
org.apache.derby.client.net.NetPreparedStatement.readExecute_(NetPreparedStatement.java:185)
at
org.apache.derby.client.am.PreparedStatement.readExecute(PreparedStatement.java:1810)
at
org.apache.derby.client.am.PreparedStatement.executeBatchRequestX(PreparedStatement.java:2325)
... 3 more
Caused by: org.apache.derby.client.am.SqlException: Error for batch element #0:
Java exception: 'Stream has already been
read and end-of-file reached and cannot be re-used.: java.io.EOFException'.
at org.apache.derby.client.am.SqlException.<init>(SqlException.java:292)
at org.apache.derby.client.am.SqlException.<init>(SqlException.java:259)
... 10 more
~/repro/derby-6214 $
The full exception from the derby.log is:
Mon May 06 11:30:40 PDT 2013 Thread[DRDAConnThread_11,5,main] (XID = 168),
(SESSIONID = 3), (DATABASE = ClobTest), (DRDAID =
????????.????-653020578103681136{2}), Failed Statement is: UPDATE Test3 SET C16
= ?, S05 = ?, I06 = ?, I07 = I07 + 1 WHERE S02 IN (?, ?) with 5 parameters
begin parameter #1:
CLOB(org.apache.derby.iapi.types.ReaderToUTF8Stream@de907da4) :end parameter
begin parameter #2: GGGGGGGG :end parameter begin parameter #3: 4002 :end
parameter begin parameter #4: AAAAA :end parameter begin parameter #5: EEEEE
:end parameter
ERROR XSDA4: An unexpected exception was thrown
at
org.apache.derby.iapi.error.StandardException.newException(StandardException.java:279)
at
org.apache.derby.impl.store.raw.data.UpdateOperation.<init>(UpdateOperation.java:110)
at
org.apache.derby.impl.store.raw.data.LoggableActions.actionUpdate(LoggableActions.java:80)
at
org.apache.derby.impl.store.raw.data.StoredPage.doUpdateAtSlot(StoredPage.java:8703)
at
org.apache.derby.impl.store.raw.data.BasePage.updateAtSlot(BasePage.java:1064)
at
org.apache.derby.impl.store.access.conglomerate.GenericConglomerateController.replace(GenericConglomerateController.java:486)
at
org.apache.derby.impl.sql.execute.RowChangerImpl.updateRow(RowChangerImpl.java:523)
at
org.apache.derby.impl.sql.execute.UpdateResultSet.collectAffectedRows(UpdateResultSet.java:568)
at
org.apache.derby.impl.sql.execute.UpdateResultSet.open(UpdateResultSet.java:263)
at
org.apache.derby.impl.sql.GenericPreparedStatement.executeStmt(GenericPreparedStatement.java:438)
at
org.apache.derby.impl.sql.GenericPreparedStatement.execute(GenericPreparedStatement.java:319)
at
org.apache.derby.impl.jdbc.EmbedStatement.executeStatement(EmbedStatement.java:1242)
at
org.apache.derby.impl.jdbc.EmbedPreparedStatement.executeStatement(EmbedPreparedStatement.java:1692)
at
org.apache.derby.impl.jdbc.EmbedPreparedStatement.execute(EmbedPreparedStatement.java:1347)
at
org.apache.derby.impl.drda.DRDAStatement.execute(DRDAStatement.java:706)
at
org.apache.derby.impl.drda.DRDAConnThread.parseEXCSQLSTTobjects(DRDAConnThread.java:4332)
at
org.apache.derby.impl.drda.DRDAConnThread.parseEXCSQLSTT(DRDAConnThread.java:4149)
at
org.apache.derby.impl.drda.DRDAConnThread.processCommands(DRDAConnThread.java:1037)
at
org.apache.derby.impl.drda.DRDAConnThread.run(DRDAConnThread.java:295)
Caused by: java.io.EOFException: Stream has already been read and end-of-file
reached and cannot be re-used.
at
org.apache.derby.iapi.types.ReaderToUTF8Stream.read(ReaderToUTF8Stream.java:254)
at
org.apache.derby.impl.store.raw.data.MemByteHolder.write(MemByteHolder.java:146)
at
org.apache.derby.impl.store.raw.data.RememberBytesInputStream.fillBuf(RememberBytesInputStream.java:135)
at
org.apache.derby.impl.store.raw.data.StoredPage.logColumn(StoredPage.java:6238)
at
org.apache.derby.impl.store.raw.data.StoredPage.logRow(StoredPage.java:4013)
at
org.apache.derby.impl.store.raw.data.UpdateOperation.writeOptionalDataToBuffer(UpdateOperation.java:255)
at
org.apache.derby.impl.store.raw.data.UpdateOperation.<init>(UpdateOperation.java:106)
... 17 more
============= begin nested exception, level (1) ===========
java.io.EOFException: Stream has already been read and end-of-file reached and
cannot be re-used.
at
org.apache.derby.iapi.types.ReaderToUTF8Stream.read(ReaderToUTF8Stream.java:254)
at
org.apache.derby.impl.store.raw.data.MemByteHolder.write(MemByteHolder.java:146)
at
org.apache.derby.impl.store.raw.data.RememberBytesInputStream.fillBuf(RememberBytesInputStream.java:135)
at
org.apache.derby.impl.store.raw.data.StoredPage.logColumn(StoredPage.java:6238)
at
org.apache.derby.impl.store.raw.data.StoredPage.logRow(StoredPage.java:4013)
at
org.apache.derby.impl.store.raw.data.UpdateOperation.writeOptionalDataToBuffer(UpdateOperation.java:255)
at
org.apache.derby.impl.store.raw.data.UpdateOperation.<init>(UpdateOperation.java:106)
at
org.apache.derby.impl.store.raw.data.LoggableActions.actionUpdate(LoggableActions.java:80)
at
org.apache.derby.impl.store.raw.data.StoredPage.doUpdateAtSlot(StoredPage.java:8703)
at
org.apache.derby.impl.store.raw.data.BasePage.updateAtSlot(BasePage.java:1064)
at
org.apache.derby.impl.store.access.conglomerate.GenericConglomerateController.replace(GenericConglomerateController.java:486)
at
org.apache.derby.impl.sql.execute.RowChangerImpl.updateRow(RowChangerImpl.java:523)
at
org.apache.derby.impl.sql.execute.UpdateResultSet.collectAffectedRows(UpdateResultSet.java:568)
at
org.apache.derby.impl.sql.execute.UpdateResultSet.open(UpdateResultSet.java:263)
at
org.apache.derby.impl.sql.GenericPreparedStatement.executeStmt(GenericPreparedStatement.java:438)
at
org.apache.derby.impl.sql.GenericPreparedStatement.execute(GenericPreparedStatement.java:319)
at
org.apache.derby.impl.jdbc.EmbedStatement.executeStatement(EmbedStatement.java:1242)
at
org.apache.derby.impl.jdbc.EmbedPreparedStatement.executeStatement(EmbedPreparedStatement.java:1692)
at
org.apache.derby.impl.jdbc.EmbedPreparedStatement.execute(EmbedPreparedStatement.java:1347)
at
org.apache.derby.impl.drda.DRDAStatement.execute(DRDAStatement.java:706)
at
org.apache.derby.impl.drda.DRDAConnThread.parseEXCSQLSTTobjects(DRDAConnThread.java:4332)
at
org.apache.derby.impl.drda.DRDAConnThread.parseEXCSQLSTT(DRDAConnThread.java:4149)
at
org.apache.derby.impl.drda.DRDAConnThread.processCommands(DRDAConnThread.java:1037)
at
org.apache.derby.impl.drda.DRDAConnThread.run(DRDAConnThread.java:295)
============= end nested exception, level (1) ===========
Cleanup action complete
> PreparedStatement.setObject(int, Object, Types.CLOB) fail with DerbyNet
> -----------------------------------------------------------------------
>
> Key: DERBY-6214
> URL: https://issues.apache.org/jira/browse/DERBY-6214
> Project: Derby
> Issue Type: Bug
> Affects Versions: 10.8.3.0, 10.9.1.0
> Reporter: Rong Qu
> Priority: Critical
> Attachments: Derby6214.java, Derby6214_setup.sql, derby.log,
> DerbyNet_client_test.sql
>
>
> The issue is specific to the DerbyNet client driver, and doesn't seem to
> occur using embedded Derby.
> "PreparedStatement.setObject(int, Object, Types.CLOB)". It seems to be a
> problem updating a CLOB column with a parameterized value using the DerbyNet
> client driver, and if the update SQL ends up updating more than one row. I
> attached a simple test case that just uses JDBC to reproduce the error. The
> exception looks like this:
> org.apache.derby.client.am.BatchUpdateException: Non-atomic batch failure.
> The batch was submitted, but at least one exception occurred on an individual
> member of the batch. Use getNextException() to retrieve the exceptions for
> specific batched elements.
> at org.apache.derby.client.am.Agent.endBatchedReadChain(Unknown Source)
> at
> org.apache.derby.client.am.PreparedStatement.executeBatchRequestX(Unknown
> Source)
> at org.apache.derby.client.am.PreparedStatement.executeBatchX(Unknown
> Source)
> at org.apache.derby.client.am.PreparedStatement.executeBatch(Unknown
> Source)
> ...
> Caused by: org.apache.derby.client.am.SqlException: Error for batch element
> #0: An unexpected exception was thrown
> at org.apache.derby.client.am.Statement.completeExecute(Unknown Source)
> at
> org.apache.derby.client.net.NetStatementReply.parseEXCSQLSTTreply(Unknown
> Source)
> at org.apache.derby.client.net.NetStatementReply.readExecute(Unknown
> Source)
> at org.apache.derby.client.net.StatementReply.readExecute(Unknown Source)
> at org.apache.derby.client.net.NetPreparedStatement.readExecute_(Unknown
> Source)
> at org.apache.derby.client.am.PreparedStatement.readExecute(Unknown
> Source)
> ... 4 more
> Caused by: org.apache.derby.client.am.SqlException: Error for batch element
> #0: Java exception: 'Stream has already been read and end-of-file reached and
> cannot be re-used.: java.io.EOFException'.
> at org.apache.derby.client.am.SqlException.<init>(Unknown Source)
> at org.apache.derby.client.am.SqlException.<init>(Unknown Source)
> ... 10 more
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira