但是会出现 num 为负数的问题,如果库存为负数,显然是不合理的 。
于是,需要将 num 字段设置为 无符号整型,这样就不会出现负数了,因为,如果减到负数,就会更新失败 。
但是这种依然会造成很多无用的更新语句的执行,是不合理的 。
于是,update table xxx set num = num - 1 where num0,
这样当 num 等于0之后就不会去更新数据库了,减少了很多无用的开销 。
这种方式被称作“乐观锁”
此外,对于抢红包这种非整数的操作 , 我们应该转换为整数的操作 。
关于抢购超卖的控制
一般抢购功能是一个相对于正常售卖系统来说独立的子系统 , 这样既可以防止抢购时的高并发影响到正常系统 ,
也可以做到针对于抢购业务的特殊处理 。
在后台设计一些功能 , 可以就昂正常的商品加入到抢购活动中并编辑成为抢购商品 , 写入到抢购商品表,当然
也可以把抢购商品表写入redis而不是数据表 。并且在原商品表写入一个同样的商品(id相同 , 用于订单查看,
此商品不可购买)
如果是数据表,为了控制超卖,需要对表进行行锁,更新的时候带上 where goods_amount0 。
如果是redis,使用 hincrby 一个负数来减库存,并且 hincrby 会返回改变后的值,再来判断返回值是否大于0,
因为redis每个命令都是原子性的,这样不用锁表就可控制超卖 。
php抓取数据的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于php获取数据、php抓取数据的信息别忘了在本站进行查找喔 。
推荐阅读
- 斗鱼直播需要哪些技术呢,斗鱼直播需要什么要求
- linux命令行概述,linux运维概述
- redis状态错误,redis error
- 区块链赋能作用,区块链赋能作用有哪些
- 三丰云mysql怎么用 三丰云教程
- python变量选择方法,python如何限制变量取值范围
- cpu烧了会什么声音,cpu烧了算不算人为损坏
- 在抖音上怎么快速直播,抖音怎么快速开直播
- python创建库函数 python创建一个数据库stuinfo