mysql处理高并发加锁.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
mysql处理高并发加锁

 HYPERLINK /caomiao2006/article/detailsmysql处理高并发,防止库存超卖  2014-08-14 23:44 17978人阅读  HYPERLINK /caomiao2006/article/details\l comments 评论(2)  HYPERLINK javascript:void(0); \o 收藏 \t _blank 收藏  HYPERLINK /caomiao2006/article/details\l report \o 举报 举报 分类: 数据库(43) 今天王总又给我们上了一课,其实mysql处理高并发,防止库存超卖的问题,在去年的时候,王总已经提过;但是很可惜,即使当时大家都听懂了,但是在现实开发中,还是没这方面的意识。今天就我的一些理解,整理一下这个问题,并希望以后这样的课程能多点。 先来就库存超卖的问题作描述:一般电子商务网站都会遇到如团购、秒杀、特价之类的活动,而这样的活动有一个共同的特点就是访问量激增、上千甚至上万人抢购 一个商品。然而,作为活动商品,库存肯定是很有限的,如何控制库存不让出现超买,以防止造成不必要的损失是众多电子商务网站程序员头疼的问题,这同时也是 最基本的问题。 从技术方面剖析,很多人肯定会想到事务,但是事务是控制库存超卖的必要条件,但不是充分必要条件。 举例: 总库存:4个商品 请求人:a、1个商品 b、2个商品 c、3个商品 程序如下: beginTranse(开启事务) try{ ??? $result = $dbca-query(select amount from s_store where postID = 12345); ??? if(result-amount 0){ ????????//quantity为请求减掉的库存数量 ????????$dbca-query(update s_store set amount = amount -?quantity?where postID = 12345); ????} }catch($e Exception){ ????rollBack(回滚) } commit(提交事务) 以上代码就是我们平时控制库存写的代码了,大多数人都会这么写,看似问题不大,其实隐藏着巨大的漏洞。数据库的访问其实就是对磁盘文件的访问,数据库中的 表其实就是保存在磁盘上的一个个文件,甚至一个文件包含了多张表。例如由于高并发,当前有三个用户a、b、c三个用户进入到了这个事务中,这个时候会产生 一个共享锁,所以在select的时候,这三个用户查到的库存数量都是4个,同时还要注意,mysql innodb查到的结果是有版本控制的,再其他用户更新没有commit之前(也就是没有产生新版本之前),当前用户查到的结果依然是就版本; 然后是update,假如这三个用户同时到达update这里,这个时候update更新语句会把并发串行化,也就是给同时到达这里的是三个用户排个序, 一个一个执行,并生成排他锁,在当前这个update语句commit之前,其他用户等待执行,commit后,生成新的版本;这样执行完后,库存肯定为 负数了。但是根据以上描述,我们修改一下代码就不会出现超买现象了,代码如下: beginTranse(开启事务) try{ ????//quantity为请求减掉的库存数量 ??? $dbca-query(update s_store set amount = amount -?quantity?where postID = 12345); ??? $result = $dbca-query(select amount from s_store where postID = 12345); ??? if(result-amount 0){ ?????? throw new Exception(库存不足); ????} }catch($e Exception){ ????rollBack(回滚) } commit(提交事务) 另外,更简洁的方法: beginTranse(开启事务) try{ ????//quantity为请求减掉的库存数量 ??? $dbca-query(update s_store set amount = amount -?quantity?where amount=quantity and?postID = 12345); }catch($e Exception){ ????rollBack(回滚) } commit(提交事务) ================================

文档评论(0)

jiupshaieuk12 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:6212135231000003

1亿VIP精品文档

相关文档