最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

关于mysql事务行锁forupdate实现写锁的功能_MySQL

来源:动视网 责编:小采 时间:2020-11-09 19:09:12
文档

关于mysql事务行锁forupdate实现写锁的功能_MySQL

关于mysql事务行锁forupdate实现写锁的功能_MySQL:在电子商务里,经常会出现库存数量少,购买的人又特别多,大并发情况下如何确保商品数量不会被多次购买.其实很简单,利用事务+for update就可以解决.我们都知道for update实际上是共享锁,是可以被读取的.但是如何在执行时,不被读取呢.简单来说:假设现在库存
推荐度:
导读关于mysql事务行锁forupdate实现写锁的功能_MySQL:在电子商务里,经常会出现库存数量少,购买的人又特别多,大并发情况下如何确保商品数量不会被多次购买.其实很简单,利用事务+for update就可以解决.我们都知道for update实际上是共享锁,是可以被读取的.但是如何在执行时,不被读取呢.简单来说:假设现在库存


在电子商务里,经常会出现库存数量少,购买的人又特别多,大并发情况下如何确保商品数量不会被多次购买.

其实很简单,利用事务+for update就可以解决.

我们都知道for update实际上是共享锁,是可以被读取的.但是如何在执行时,不被读取呢.

简单来说:假设现在库存为1,现在有A和B同时购买

先开启一个事务

begin;

select stock from good where id=1 for update;//查询good表某个商品中stock的数量

查出来后,在程序里在判断这个stock是否为0(你用什么语言,不关我事)

最后在执行

update good set stock=stock-1 where id=1

最后在

commit

但是这个时候B也是select stock from good where id=1 for update;注意:for update不能省略..这个时候会出现被锁住,无法被读取.

所以这就能够保证了商品剩余数量为1的一致性.

文档

关于mysql事务行锁forupdate实现写锁的功能_MySQL

关于mysql事务行锁forupdate实现写锁的功能_MySQL:在电子商务里,经常会出现库存数量少,购买的人又特别多,大并发情况下如何确保商品数量不会被多次购买.其实很简单,利用事务+for update就可以解决.我们都知道for update实际上是共享锁,是可以被读取的.但是如何在执行时,不被读取呢.简单来说:假设现在库存
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top