thinkphp怎么鎖表

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

官方文檔給出的鎖表方案是:

$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

以上就是

? 版權聲明
THE END
喜歡就支持一下吧
點贊8 分享