如何使用ThinkPHP实现数据库锁表操作?
- 内容介绍
- 文章标签
- 相关推荐
本文共计639个文字,预计阅读时间需要3分钟。
相关专题:
例:
当前系统中只有用户A报名,顺序为1,记为(A, 1);
某时刻t,用户B,用户C,用户D,同时报名,后端几乎同时接收到B、C、D的报名请求,于是查询报名表发现,目前只有(A, 1),于是将(B, 2),(C, 2),(D, 2)插入报名表得到结果:
立即学习“PHP免费学习笔记(深入)”;
(A, 1)
(B, 2)
(C, 2)
(D, 2)。
个人最开始想到的办法是:我不记录顺序,我记录插入时间戳,这样的话就是
(A, ta)
(B, tb)
(C, tc)
(D, td)。
ta, tb, tc, td几乎不可能出现相等的情况。
相关推荐:《ThinkPHP教程》
但是这样做有三个问题无法解决:
1.有可能出现时间戳相等的情况,概率很低;
2.不直观,需要用时间戳排序;
3.报名的时候用人数限制,比如限制报名40人,而且立即反馈当前报名是否报上。
目前的解决办法是,通过数据库加锁来解决。
网上查了很多资料,ThinkPHP可以加悲观锁和乐观锁。目标系统访问量不大,使用悲观锁就行了。
MyISAM只能锁表,InnoDB可以行锁定。目标系统锁表即可。
本文共计639个文字,预计阅读时间需要3分钟。
相关专题:
例:
当前系统中只有用户A报名,顺序为1,记为(A, 1);
某时刻t,用户B,用户C,用户D,同时报名,后端几乎同时接收到B、C、D的报名请求,于是查询报名表发现,目前只有(A, 1),于是将(B, 2),(C, 2),(D, 2)插入报名表得到结果:
立即学习“PHP免费学习笔记(深入)”;
(A, 1)
(B, 2)
(C, 2)
(D, 2)。
个人最开始想到的办法是:我不记录顺序,我记录插入时间戳,这样的话就是
(A, ta)
(B, tb)
(C, tc)
(D, td)。
ta, tb, tc, td几乎不可能出现相等的情况。
相关推荐:《ThinkPHP教程》
但是这样做有三个问题无法解决:
1.有可能出现时间戳相等的情况,概率很低;
2.不直观,需要用时间戳排序;
3.报名的时候用人数限制,比如限制报名40人,而且立即反馈当前报名是否报上。
目前的解决办法是,通过数据库加锁来解决。
网上查了很多资料,ThinkPHP可以加悲观锁和乐观锁。目标系统访问量不大,使用悲观锁就行了。
MyISAM只能锁表,InnoDB可以行锁定。目标系统锁表即可。

