假设一个mysql数据库表为stock,商品id是prodid
表如下
stocknums prodid
105 10200001
我们对商品编号为1020001的商品减库存100,我们使用mysql的行锁来解决,代码如下:
SELECT stocknums FROM 'stock' WHERE prodid = 10200001 FROM UPDATE;请记住,后面的where stocknums>=100是解决超卖的关键。
UPDATE stock SET stocknums=stocknums-100 WHERE stocknum>=100 AND prodid=10200001;
那么如果使用redis怎么解决呢?
使用decrby 原子操作,返回小于0就表示超卖,代码如下:
decrby 10200001 100
网友回复
linux stream如何限制单个目录最大容量?
哪有免费的千问qwen3.6-plus的api可以使用?
python如何自动根据视频图片等素材自动按照要求剪辑视频生成剪映草稿?
gemma4与开源的qwen3.5哪个更厉害?
wan2.7 video与seedance2哪个更好?
claude code 51万行代码泄露被迫开源在哪能找到源码?
有没有免费的虚拟局域网工具可以将互联网设备组成一个大的局域网?
全球顶尖大模型这么强,为啥AGI 测试集体溃败 人类满分 AI 最高仅 0.37%?
听说字节seedance3的视频生成长度可达到10分钟?
谷歌的TurboQuant是不是真的?


