【Oracle】悲观锁和乐观锁

悲观锁
    如select * for update
    悲观锁大多数情况下依靠数据库的锁机制实现,以保证操作最大程度的独占性。但随之而来的就是数据库性能的大量开销,特别是对长事务而言,这样            的开销往往无法承受。
 
乐观锁
    基于数据版本(version)机制实现:为数据增加一个版本标识,在基于数据库表的版本解决方案中,一般是通过为数据库表增加一个 “version” 字段来实现。读取出数据时,将此版本号一同读出,之后更新时,对此版本号加一。此时,将提交数据的版本数据与数据库表对应记录的当前版本信息进行比对,如果提交的数据版本号大于数据库表当前版本号,则予以更新,否则认为是过期数据。
 
在设计乐观锁时,只针对系统内部对数据的操作,如果数据来自于系统外部(其他系统直接操作数据库),则可能造成脏数据。可以考虑将乐观锁策略在数据库存储过程中实现,对外只开放基于此存储过程的数据更新途径,而不是将数据库表直接对外公开。
 
原文地址:https://www.cnblogs.com/liuyongcn/p/3567846.html