最近需要寫一個並發量不是很大的報名系統,但還是有可能出現多人同時報名的情況。因為報名涉及到先後順序,如果不進行鎖行或鎖定表,會出現下列這種情況:
#例:
當前系統中只有用戶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中文網其他相關文章!