分享

Hibernate入门之悲观锁定(28)

 WindySky 2007-07-15
悲观锁定
 在多个客户端可能读取同一笔数据或同时更新一笔数据的情况下,必须要有访问控制的手段,防止同一个数据被修改而造成混乱,最简单的手段就是对数据进行锁定,在自己进行数据读取或更新等动作时,锁定其它客户端不能对同一笔数据进行任何的动作。
 悲观锁定(Pessimistic Locking)一如其名称所示,悲观的认定每次资料存取时,其它的客户端也会存取同一笔数据,因此对该笔数据进行锁定,直到自己操作完成后解除锁定。
 悲观锁定通常透过系统或数据库本身的功能来实现,依赖系统或数据库本身提供的锁定机制,Hibernate即是如此,我们可以利用Query或Criteria的setLockMode()方法来设定要锁定的表或列(row)及其锁定模式,锁定模式有以下的几个:
• LockMode.WRITE:在insert或update时进行锁定,Hibernate会在save()方法时自动获得锁定。
• LockMode.UPGRADE:利用SELECT ... FOR UPDATE进行锁定。
• LockMode.UPGRADE_NOWAIT:利用SELECT ... FOR UPDATE NOWAIT进行锁定,在Oracle环境下使用。
• LockMode.READ:在读取记录时Hibernate会自动获得锁定。
• LockMode.NONE:没有锁定。
 也可以在使用Session的load()或是lock()时指定锁定模式以进行锁定。
 如果数据库不支持所指定的锁定模式,Hibernate会选择一个合适的锁定替换,而不是丢出一个例外(Hibernate参考手册10.6)。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多