如何使用ThinkPHP实现数据库锁表操作?

2026-05-07 17:140阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计639个文字,预计阅读时间需要3分钟。

如何使用ThinkPHP实现数据库锁表操作?

相关专题:

例:

当前系统中只有用户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分钟。

如何使用ThinkPHP实现数据库锁表操作?

相关专题:

例:

当前系统中只有用户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可以行锁定。目标系统锁表即可。

阅读全文