You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@openjpa.apache.org by "Bogdan Stroe (JIRA)" <ji...@apache.org> on 2008/07/17 16:33:31 UTC

[jira] Commented: (OPENJPA-530) Statement batching incorrectly re-arranged order of SQL statements organized by update managers

    [ https://issues.apache.org/jira/browse/OPENJPA-530?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12614361#action_12614361 ] 

Bogdan Stroe commented on OPENJPA-530:
--------------------------------------

This problem appears in OpenJPA 1.0.2 also.
As a work-around (that loses the batch performance improvement as no batch is done at all) one can set this property in persistence.xml:
<property name="openjpa.jdbc.UpdateManager" value="operation-order"/>

> Statement batching incorrectly re-arranged order of SQL statements organized by update managers
> -----------------------------------------------------------------------------------------------
>
>                 Key: OPENJPA-530
>                 URL: https://issues.apache.org/jira/browse/OPENJPA-530
>             Project: OpenJPA
>          Issue Type: Bug
>          Components: jdbc
>    Affects Versions: 1.1.0
>            Reporter: Albert Lee
>            Assignee: Albert Lee
>             Fix For: 1.1.0
>
>         Attachments: OPENJPA-530.patch
>
>
> BatchingPreparedStatementManagerImpl implements the core SQL statement execution function of the Statement Batching features. 
> The current implementation of this class holds a cache that maps SQL prepared statements to a collection of parameters of batched requests for that prepared statement. When update manager finishes batching its requests, BatchingPreparedStatementManagerImpl.flush() method is called to submit the batch elements in the cache to the jdbc driver.
> Essentially, this implementation discards all the ordering of statements being dispatched to the statement batching function by the update manager. This caused improper order of SQL statements to be sent to the data store. As a result, the underlying database may throw exception indicates the unexpected data condition. E.g. 
> com.ibm.db2.jcc.b.SqlException: Error for batch element #2: DB2 SQL error: SQLCODE: -530, SQLSTATE: 23503, SQLERRMC: LEEALBER.EMPBEAN.SQL080226132752530
> SQL0530N: The insert or update value of the FOREIGN KEY constraint-name is not equal to any value of the parent key of the parent table. 

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.