ThinkPHP併發下鎖表

參考連接: http://blog.coinidea.com/web%E5%BC%80%E5%8F%91/php-1261.htmlphp

最近須要寫一個併發量不是很大的報名系統,可是仍是有可能出現多人同時報名的狀況。由於報名html

涉及到前後順序,若是不進行鎖行或者鎖表,會出現下列這種狀況。 例: 當前系統中只有用戶A報名,順序爲1,記爲(A, 1); 某時刻t,用戶B,用戶C,用戶D,同時報名,後端幾乎同時接收到B、C、D的報名請求,因而查詢web

報名表發現,目前只有(A, 1),因而將(B, 2),(C, 2),(D, 2)插入報名表獲得結果:數據庫

(A, 1)後端

(B, 2)併發

(C, 2)ide

(D, 2)。idea

我的最開始想到的辦法是:我不記錄順序,我記錄插入時間戳,這樣的話就是code

(A, ta)htm

(B, tb)

(C, tc)

(D, td)。

ta, tb, tc, td幾乎不可能出現相等的狀況。

可是這樣作有三個問題沒法解決,

  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

參考連接: http://blog.coinidea.com/web%E5%BC%80%E5%8F%91/php-1261.html

相關文章
相關標籤/搜索