假设一个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
网友回复
python如何调用openai的api实现知识讲解类动画讲解视频的合成?
html如何直接调用openai的api实现海报可视化设计及文本描述生成可编辑海报?
f12前端调试如何找出按钮点击事件触发的那段代码进行调试?
abcjs如何将曲谱播放后导出mid和wav格式音频下载?
python如何将曲子文本生成音乐mp3或wav、mid文件
python中mp3、wav音乐如何转成mid格式?
js在HTML中如何将曲谱生成音乐在线播放并下载本地?
python如何实现在windows上通过键盘来模拟鼠标操作?
python如何给win10电脑增加文件或文件夹右键自定义菜单?
python如何将音乐mp3文件解析获取曲调数据?