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

时间:2016.04.27 发布人:xiaoxi0o

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

已解决问题

谷歌xiaoxi0o用户在2016.04.27提交了关于“满江红关于mysql事务行锁forupdate实现写锁的功能”的提问,欢迎大家涌跃发表自己的观点。目前共有1个回答,最后更新于2025-03-03T05:33:28。希望大家能够帮助她。

详细问题描述及疑问:期待您的答案,希望你能感受到,我最真诚的谢意 !

希望以下的回答,能够帮助你。

第1个回答

用户名:bluebaby2012  

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

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

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

  简单来说:假设现事殖岩认罪大风在库存为1,现在有A协款我才北心皮培益和B同时购买

  先开启一个事务

  begin;

  selectstockfromgoodwhereid=1forupdate;//查询good表某个商品中stock的数量

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

  最后在执行

  updategoodsetstock断任场茶固良压流=stock-1wherei张力d=1

  最后在

  c圆岁城由语项罪鲁感ommit

  但是这个时候B也是selectstockfromgoodwhereid=1forupdate;注意:forupdate不能省略..这个时候会出现被锁住,无法被读取.

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