全。
我使用纯JPA编写了一个程序,它的提供者是hibernate,底层数据库是Azure SQL DB。这个程序将在分布式环境下运行,它的许多副本将在不同的服务器上运行。
我需要一些这样的程序(对于ex-):
1,锁定指定的学生实体,
2、检查类实体状态,如果状态为1,则继续,否则,尝试锁定该类实体,直到获得该类的锁
3、检查状态(由于分布式环境,可能会被其他服务器上的其他线程修改),如果仍然不是1,则做点什么,将状态修改为1,
4、解锁此类实体
5、做其他事情(仍然保持对当前学生实体的锁定)
我被以下代码seg锁住了:
Map<String,Object> map = new HashMap<String, Object>();
map.put("javax.persistence.lock.timeout", 0);
return this.getEntityManager().find( cls, id, LockModeType.PESSIMISTIC_WRITE,map);但是,我不知道如何在第四步释放锁,有没有什么方法可以只在一个实体上实现锁,并保留其他锁?
非常感谢,任何建议都将被采纳。
发布于 2013-06-07 16:33:03
您必须将锁定模式设置为none
em.lock(myEntity, LockModeType.NONE);请参阅http://www.objectdb.com/java/jpa/persistence/lock
https://stackoverflow.com/questions/16975764
复制相似问题