首頁  >  文章  >  php框架  >  thinkphp怎麼鎖表

thinkphp怎麼鎖表

爱喝马黛茶的安东尼
爱喝马黛茶的安东尼原創
2019-08-22 11:33:274729瀏覽

thinkphp怎麼鎖表

最近需要寫一個並發量不是很大的報名系統,但還是有可能出現多人同時報名的情況。因為報名涉及到先後順序,如果不進行鎖行或鎖定表,會出現下列這種情況:

#例:

當前系統中只有用戶A報名,順序為1,記為(A, 1);

某時刻t,用戶B,用戶C,用戶D,同時報名,後端幾乎同時接收到B、C、D的報名請求,於是查詢報名表發現,目前只有(A, 1),於是將(B, 2),(C, 2),(D, 2)插入報名表得到結果:

(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可以行鎖定。目標系統鎖表即可。

官方文件給出的鎖定表方案是:

$User->lock(true)->save($data);// 使用悲观锁功能

但是目標系統要進行一些列操作,所以使用的鎖定表程式碼是:

M()->query("lock tables yourtable write");
// TODO
// your code
M()->query("unlock tables");

實際效果運行效果還不錯[真實日期已被過濾]:

??-??-?? 10:00:00   1
??-??-?? 10:00:00   2
??-??-?? 10:00:00   3
??-??-?? 10:00:00   4
??-??-?? 10:00:01   5
??-??-?? 10:00:01   6
??-??-?? 10:00:01   7
??-??-?? 10:00:01   8
??-??-?? 10:00:02   9
??-??-?? 10:00:02   10
??-??-?? 10:00:02   11
??-??-?? 10:00:02   12
??-??-?? 10:00:02   13
??-??-?? 10:00:02   14
??-??-?? 10:00:03   15
??-??-?? 10:00:03   16
??-??-?? 10:00:03   17
??-??-?? 10:00:05   18
??-??-?? 10:00:06   19
??-??-?? 10:00:07   20
??-??-?? 10:00:08   21
??-??-?? 10:00:10   22
??-??-?? 10:00:15   23
??-??-?? 10:00:17   24
??-??-?? 10:00:19   25
??-??-?? 10:00:19   26
??-??-?? 10:00:24   27
??-??-?? 10:00:25   28
??-??-?? 10:00:34   29
??-??-?? 10:00:35   30
??-??-?? 10:00:38   31
??-??-?? 10:01:06   32
??-??-?? 10:01:11   33
??-??-?? 10:01:11   34
??-??-?? 10:01:17   35
??-??-?? 10:01:18   36
??-??-?? 10:02:27   37
??-??-?? 10:02:38   38
??-??-?? 10:02:39   39
??-??-?? 10:02:57   40

以上是thinkphp怎麼鎖表的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn