php抓取数据 php获取数据( 三 )


但是会出现 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抓取数据的信息别忘了在本站进行查找喔 。

推荐阅读