一:乐观锁
乐观锁不是数据库自带的,需要我们自己去实现。乐观锁是指操作数据库时(更新操作),想法很乐观,认为这次的操作不会导致冲突,在操作数据时,并不进行任何其他的特殊处理(也就是不加锁),而在进行更新后,再去判断是否有冲突。
通常的实现方法是:
在表中的数据进行操作时(更新),先给数据表加一个版本(version)字段,每操作一次,将那条记录的版本号加1。也就是先查询出那条记录,获取出version字段,如果要对那条记录进行操作(更新),则先判断此刻version的值是否与刚刚查询出来时的version的值相等,如果相等,则说明这段期间,没有其他程序对其进行操作,则可以执行更新,将version字段的值加1;如果更新时发现此刻的version值与刚刚获取出来的version的值不相等,则说明这段期间已经有其他程序对其进行操作了,则不进行更新操作。
二 :悲观锁
与乐观锁相对应的就是悲观锁了。悲观锁就是在操作数据时,认为此操作会出现数据冲突,所以在进行每次操作时都要通过获取锁才能进行对相同数据的操作,这点跟java中的synchronized很相似,所以悲观锁需要耗费较多的时间。另外与乐观锁相对应的,悲观锁是由数据库自己实现了的,要用的时候,我们直接调用数据库的相关语句就可以了
三:共享锁
共享锁指的就是对于多个不同的事务,对同一个资源共享同一个锁。相当于对于同一把门,它拥有多个钥匙一样。就像这样,你家有一个大门,大门的钥匙有好几把,你有一把,你女朋友有一把, 你们都可以通过钥匙进入房间。
在Mysql中, 在执行语句后面加上lock in share mode就代表对某些资源加上共享锁了
图1 为一个简单的user表。
BEGIN;
SELECT * from test.`user` where test.user.id = '1' lock in SHARE MODE;
随后在另外一个 窗口加上如下语句 :
UPDATE test.`user`
SET test.`user`.`name` = 'chw123'
WHERE
test.`user`.id = 1
执行该语句之后 ,页面会卡顿一下,如图 2 ,过几秒钟 之后 ,会报如图3一样的错误。
图2
图3
三:排它锁
排它锁与 共享锁想对应 ,对于多个不同的事务,对同一个资源只能有一把锁。