本篇文章给大家带来的内容是关于MySQL中乐观锁和悲观锁的介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。悲观锁悲观锁,它指的是对数据被外界(包括本系统当前的其他事务,以及来自外部系统的事务处理)修改持保守态度(悲观),因此在整个暑假处理过程中,将数据处于锁定状态。悲观锁的实现,一般依靠数据库提供的锁机制(推荐教程:MySQL教程) 数据库中,悲观锁的流程如下 在对任何记录进行修改之前,先尝试为该记录加上排他锁 如果加锁失败,说明该记录正在被修改,那么当前查询可能要等待或抛出异常 如果成功加锁,则就可以对记录做修改,事务完成后就会解锁 其间如果有其他对该记录做修改或加排他锁的操作,都会等待我们解锁或直接抛出异常
MySQL InnoDB中使用悲观锁要使用悲观锁,必须关闭mysql数据库的自动提交属性,因为MySQL默认使用autocommit模式,也就是当你执行一个更新操作后,MySQL会立即将结果进行提交
//开始事务
begin;/begin work;/start transaction;(三者选一个)
select status from t_goods where id=1 for update;
//根据商品信息生成订单
insert into t_orders (id,goods_id) values (null,1);
//修改商品status为2
update t_goods set status=2;
// 提交事务
commit;/commit work; 以上查询语句中,使用了select...for update方式,通过开启排他锁的方式实现了悲观锁。则相应的记录被锁定,其他事务必须等本次事务提交之后才能够执行 我们使用select ... for update会把数据给锁定,不过我们需要注意一些锁的级别,MySQL InnoDB默认行级锁。行级锁都是基于索引的,如果一条SQL用不到索引是不会使用行级锁的,会使用表级锁把整张表锁住。
特点乐观锁乐观锁相对悲观锁而言,是假设数据不会发生冲突,所以在数据进行提交更新的时候,才会正式对数据的冲突与否进行检测,如果发现冲突了,则让返回用户错误信息,让用户决定如何做 实现使用版本号时,可以在数据初始化时指定一个版本号,每次对数据的更新操作都对版本号执行+1操作。并判断当前版本号是不是该数据的最新版本号 1.查询出商品信息
select (status,status,version) from t_goods where id=#{id}
2.根据商品信息生成订单
3.修改商品status为2
update t_goods
set status=2,version=version+1
where id=#{id} and version=#{version}; 特点乐观并发控制相信事务之间的数据竞争概率是较小的,因此尽可能直接做下去,直到提交的时候才去锁定,所以不会产生任何锁和死锁 以上就是MySQL中乐观锁和悲观锁的介绍(代码示例)的详细内容,更多请关注模板之家(www.mb5.com.cn)其它相关文章! |