[ 
https://issues.apache.org/jira/browse/OPENJPA-1142?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Donald Woods updated OPENJPA-1142:
----------------------------------

    Affects Version/s:     (was: 2.0.0)
                           (was: 2.0.0-M2)
                       2.0.0-M3
        Fix Version/s:     (was: 2.0.0-beta2)
                           (was: 2.0.0)
                       2.0.0-beta

> OptimisticLockException thrown on Query.getResultList() when Pessimistic Lock 
> is applied
> ----------------------------------------------------------------------------------------
>
>                 Key: OPENJPA-1142
>                 URL: https://issues.apache.org/jira/browse/OPENJPA-1142
>             Project: OpenJPA
>          Issue Type: Bug
>          Components: kernel
>    Affects Versions: 2.0.0-M3
>            Reporter: Albert Lee
>            Assignee: Albert Lee
>             Fix For: 2.0.0-beta
>
>         Attachments: OPENJPA-1142.patch
>
>
> The following sample code snippet may yield a OptimisticLockException.
>     Query tc_query = 
> itemManager.createNamedQuery("TypeCategory.find_tc").setParameter("product_id",
>  new Integer(product_id));                
>     tc_query.setLockMode(LockModeType.PESSIMISTIC_READ);
>     Collection typeCat = tc_query.getResultList();
> This is a incorrect behavior per JPA 2.0 spec:
> public interface Query {
>   /**
>    * Execute a SELECT query and return the query results
>    * as an untyped List.
>    * @return a list of the results
>    * @throws IllegalStateException if called for a Java Persistence query 
> language UPDATE or DELETE statement
>    * @throws QueryTimeoutException if the query execution exceeds the query 
> timeout value set
>    * @throws TransactionRequiredException if a lock mode has been set and 
> there is no transaction
>    * @throws PessimisticLockException if pessimistic locking fails and the 
> transaction is rolled back
>    * @throws LockTimeoutException if pessimistic locking fails and only the 
> statement is rolled back
>    */
>   List getResultList();

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

Reply via email to