zoukankan      html  css  js  c++  java
  • 关于mysql事务行锁for update实现写锁的功能


    读后感:用切面编程的理论来讲,数据库的锁对于业务来说是透明的。spring的事务管理代码,业务逻辑代码,表锁,应该是三个不同的设计层面。

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

    其实很简单,利用事务+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的一致性
  • 相关阅读:
    python3-基础11
    python3-基础10
    python3-基础9
    python3-基础8
    python3-基础7
    python3-基础6
    phaserjs 总结
    ES6总结
    移动端webview调试
    nodejs的理解
  • 原文地址:https://www.cnblogs.com/jpfss/p/9364956.html
Copyright © 2011-2022 走看看