php mysql并发_php mysql 并发问题?

php sql 都是发给mysql一条一条执行的吗?

如果同时有两条更新的sql,都是操作同一行数据,那么这两条sql是怎么执行的呢,一条先执行一条后执行吗?

如果是先后执行的,那么是否可以理解为执行sql时进行了自动的锁表呢?

还有这个问题:

我以前用MyIsam出现这样一个问题,应用场景是这样的:A和B用户之间发消息(web办聊天框AJAX),A给B每发一条消息,消息表中新增一条记录(未读消息标示),然后同时B的未读消息+1, 而B每隔几秒AJAX请求看消息表中是否有新的未读消息,有则取回,标示为已读消息,然后未读字段减去这个未读消息的数量,这样的设计本来没什么问题,但是如果发消息和刷新消息很快毫秒级那么就出问题了,用JS模拟点击,出现的问题是,再A停止发消息后,B用户的未读字段竟然不是0,本来好好的,为什么发消息快事就成这样了呢,这让我崩溃了,这还了得,如果涉及到金额那不就完了啊,这个问题是什么原因呢?

回复内容:

php sql 都是发给mysql一条一条执行的吗?

如果同时有两条更新的sql,都是操作同一行数据,那么这两条sql是怎么执行的呢,一条先执行一条后执行吗?

如果是先后执行的,那么是否可以理解为执行sql时进行了自动的锁表呢?

还有这个问题:

我以前用MyIsam出现这样一个问题,应用场景是这样的:A和B用户之间发消息(web办聊天框AJAX),A给B每发一条消息,消息表中新增一条记录(未读消息标示),然后同时B的未读消息+1, 而B每隔几秒AJAX请求看消息表中是否有新的未读消息,有则取回,标示为已读消息,然后未读字段减去这个未读消息的数量,这样的设计本来没什么问题,但是如果发消息和刷新消息很快毫秒级那么就出问题了,用JS模拟点击,出现的问题是,再A停止发消息后,B用户的未读字段竟然不是0,本来好好的,为什么发消息快事就成这样了呢,这让我崩溃了,这还了得,如果涉及到金额那不就完了啊,这个问题是什么原因呢?

跟存储引擎有关。简单的说MyISAM是表锁,Innodb是行锁。 具体可以参考mysql手册:https://dev.mysql.com/doc/refman/5.5/en/locking-issues.html

你需要看一下有关数据库事务的介绍。http://blog.csdn.net/wang_cir/article/details/6227155

这个涉及到锁的概念——乐观锁,悲观锁。看具体情况。一般使用乐观锁处理。

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值