Glassfish 2.1でJPAに悲観的ロックを実装する方法は?
質問
次のコードを使用してロックを設定しようとするとき(悲観的):
em.lock(controlnumbers, LockModeType.WRITE);
em.refresh(controlnumbers);
次の例外が発生しています:
[#|2009-09-10T15:42:48.324-0400|INFO|sun-appserver2.1|javax.enterprise.system.container.ejb|_ThreadID=31;_ThreadName=httpSSLWorkerThread-8080-19;|
javax.ejb.TransactionRolledbackLocalException: Exception thrown from bean; nested exception is: javax.persistence.PersistenceException: ejb30-wrong-lock_called_without_version_locking-index (There is no English translation for this message.)
javax.persistence.PersistenceException: ejb30-wrong-lock_called_without_version_locking-index (There is no English translation for this message.)
at oracle.toplink.essentials.internal.ejb.cmp3.base.EntityManagerImpl.lock(EntityManagerImpl.java:619)
at com.sun.enterprise.util.EntityManagerWrapper.lock(EntityManagerWrapper.java:582)
at com.eximtechnologies.transactionserver.persistence.session.ControlNumbersFacade.lock(ControlNumbersFacade.java:43)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
Glassfish 2.1で悲観的ロックを実装するにはどうすればよいですか
解決
これを行うToplink Essentials(GF 2.1デフォルト)固有の方法があります:
public MyObject lock (MyObject controlnumbers) {
String qStr = "select object(o) from MyObject as o where o.pk = :pk";
Query q = em.createQuery(qStr);
q.setParameter("pk", "a");
q.setHint("toplink.pessimistic-lock", "Lock");
controlnumbers = (MyObject)q.getSingleResult();
return controlnumbers;
}
Hibernateでem.lockを呼び出すと実際に機能すると思います。
他のヒント
クラスのマッピングを表示できますか?バージョンプロパティが欠落しているようです...を見てください
http://en.wikibooks.org/wiki/Java_Persistence/Locking#Timestamp_Locking
よろしく、Jan
所属していません StackOverflow