php - 怎么在SQL语句SELECT的时候防止并发
天蓬老师
天蓬老师 2017-04-10 16:14:18
[PHP讨论组]

需求大概是这样的:

做了一个判断,表里面该人的记录小于5次的时候可以执行INSERT操作。
但是可能会面临这样一个问题,SELECT的时候结果是小于5次的,但是其实已经有一条INSERT的语句在写表了。那么SELECT后又写表一条,发现这个人有6条记录了!

需求是怎么把这个SELECT5次的标准严格卡死,避免这种并发带来的误操作。

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复(6)
伊谢尔伦

使用存储过程

怪我咯

只要用插入锁把表锁了就是了。

阿神
BEGIN
SELECT COUNT(1) from wen_user for UPDATE
INSERT into wen_user set name="3333333";
COMMIT

可以使用for update来操作

PHPz

可以使用mem锁机制实现

黄舟

典型加锁解决方案

迷茫

要想做到锁定行的同时还不影响性能,其实问题挺复杂的,不能简单的通过 select * for update 这种锁定读的方式来解决,需要根据你的问题的背景做一些测试,否则有可能会导致很多记录行都被锁定,导致整个系统运行缓慢。所以还是建议你把mysql的锁机制了解清楚,这样才能做到解决问题的同时还不影响性能。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号