当前位置:首页 > CMS教程 > Thinkphp > 列表

thinkPHP框架乐观锁和悲观锁实例分析

发布:smiling 来源: PHP粉丝网  添加日期:2022-01-19 10:05:55 浏览: 评论:0 

这篇文章主要介绍了thinkPHP框架乐观锁和悲观锁,结合实例形式分析了框架乐观锁和悲观锁的原理及thinkPHP相关实现技巧,需要的朋友可以参考下。

本文实例讲述了thinkPHP框架乐观锁和悲观锁,分享给大家供大家参考,具体如下:

乐观锁:

例子对于一个正在出售的火爆商品,同一个时间,同时有10个人同时发起了10个线程来购买,10个线程读取到数据库的库存有20件和version为9。

那么乐观锁读取num数量和version版本两个字段,在更新的结果时候,我们就要更新条件where version=9这条语句,具体UPDATE goods SET num=num-1,version=version+1 WHERE version=9 and id=1,这样的话,如果其中一条执行成功后,数据库中version的值为10了,所以剩下的9个人线程都会失败了。

  1. $result = $this->mysqli->query("SELECT num,version FROM goods WHERE id=1 LIMIT 1"); 
  2. $row = $result->fetch_assoc(); 
  3. $num = intval($row['num']); 
  4. $version = intval($row['version']); 
  5. if($num > 0){ 
  6.   usleep(100); 
  7.   $this->mysqli->begin_transaction(); 
  8.   $this->mysqli->query("UPDATE goods SET num=num-1,version=version+1 WHERE version={$version} and id=1"); 
  9.   $affected_rows = $this->mysqli->affected_rows; 
  10.   if($affected_rows == 1){ 
  11.     $this->mysqli->query("INSERT INTO log(good_id) VALUES({$num})"); 
  12.     $affected_rows = $this->mysqli->affected_rows; 
  13.     if($affected_rows == 1){ 
  14.       $this->mysqli->commit(); 
  15.       echo "success:".$num
  16.     }else
  17.       $this->mysqli->rollback(); 
  18.       echo "fail1:".$num
  19.     } 
  20.   }else
  21.     $this->mysqli->rollback(); 
  22.     echo "fail2:".$num
  23.   } 
  24. }else
  25.   echo "fail3:".$num

乐观锁缺点:

比如可能别人先购买的,反而后面的先买到了,这就点不太合理

乐观锁优点:

这可以避免超发的现象发生

悲观锁mysql代码:

#主要对所在行进行for update

select * from employee where id = 1 for update;

update employee set money = 0 + 1 where id = 1;

Tags: thinkPHP锁 thinkPHP悲观锁

分享到: