欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何解決PHP+MySQL高并發(fā)加鎖事務處理的問題-創(chuàng)新互聯

這篇文章將為大家詳細講解有關如何解決PHP+MySQL高并發(fā)加鎖事務處理的問題,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

為準格爾等地區(qū)用戶提供了全套網頁設計制作服務,及準格爾網站建設行業(yè)解決方案。主營業(yè)務為網站制作、成都網站制作、準格爾網站設計,以傳統方式定制建設網站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!

具體如下:

1、背景:

現在有這樣的需求,插入數據時,判斷test表有無username為‘mraz'的數據,無則插入,有則提示“已插入”,目的就是想只插入一條username為‘mraz'的記錄。

2、一般程序邏輯如下:

$conn = mysqli_connect('127.0.0.1', 'root', '111111') or die(mysqli_error());
mysqli_select_db($conn, 'mraz');
$rs = mysqli_query($conn, 'SELECT count(*) as total FROM test WHERE username = "mraz" ');
$row = mysqli_fetch_array($rs);
if($row['total']>0){
  exit('exist');
}
mysqli_query($conn, "insert into test(username) values ('mraz')");
var_dump('error:'.mysqli_errno($conn));
$insert_id = mysqli_insert_id($conn);
echo 'insert_id:'.$insert_id.'<br>';
mysqli_free_result($rs);
mysqli_close($conn);

3、一般少量請求的時候,程序邏輯不會有問題。但是一旦高并發(fā)請求執(zhí)行的話,程序并沒有按預期執(zhí)行,會插入多條username為‘mraz'的記錄。

4、解決方案利用mysql的FOR UPDATE 語句和事務的隔離性。注意的是FOR UPDATE僅適用于InnoDB,且必須在事務(BEGIN/COMMIT)中才能生效。

調整代碼后如下:

$conn = mysqli_connect('127.0.0.1', 'root', '111111') or die(mysqli_error());
mysqli_select_db($conn, 'mraz');
mysqli_query($conn, 'BEGIN');
$rs = mysqli_query($conn, 'SELECT count(*) as total FROM test WHERE username = "mraz" FOR UPDATE');
$row = mysqli_fetch_array($rs);
if($row['total']>0){
  exit('exist');
}
mysqli_query($conn, "insert into test(username) values ('mraz')");
var_dump('error:'.mysqli_errno($conn));
$insert_id = mysqli_insert_id($conn);
mysqli_query($conn, 'COMMIT');
echo 'insert_id:'.$insert_id.'<br>';
mysqli_free_result($rs);
mysqli_close($conn);

5、再利用php的curl模擬高并發(fā)請求該php腳本,查看數據庫會只有一條username為‘mraz'的記錄。達到程序執(zhí)行的預期結果~

關于“如何解決PHP+MySQL高并發(fā)加鎖事務處理的問題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

網站名稱:如何解決PHP+MySQL高并發(fā)加鎖事務處理的問題-創(chuàng)新互聯
網站地址:http://aaarwkj.com/article48/cojjep.html

成都網站建設公司_創(chuàng)新互聯,為您提供微信公眾號、軟件開發(fā)企業(yè)建站、Google、App設計、App開發(fā)

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

成都app開發(fā)公司
91高清视频在线免费观看| 午夜福利不卡片在线观看| 亚洲av二区三区成人| 国产国语激情对白在线| 国产av午夜精品福利| 91中文字幕在线一区| 欧美日韩在线一区二区| 91欧美精品一区二区| 91激情黑丝在线观看| 伊人激情久久综合中文字幕| 国产丝袜在线精品丝袜不卡| 日本高清精品视频免费| 欧美日韩午夜久久免费| 亚洲欧美日韩精品成人| 男男啪啪猛进猛出无遮挡| 欧美亚日韩精品视频| 91免费视频精品麻豆| 亚洲精品在线观看av| 亚洲精品国产精品乱码不| 日本一区二区欧美在线| 国产剧情av网址观看免费| 自偷自拍亚洲综合精品| 中文字幕在线一区国产精品| 久久亚洲天堂av丁香| 国产精品黄色av一区二区| 国产国语网站在线观看| 青青草原一区二区三区| 青青草原一区在线观看| 亚洲,日韩,欧美久久综合| 91伊人久热精品午夜福利| 成年人黄色免费网站在线观看| 免费在线观看欧美色妇| 亚洲成av人在线观看福利| 日本午夜精品在线观看| 日韩欧美国产精品加勒比| 国产三级视频网站在线观看| 亚洲熟女熟妇另类中文| 亚洲av一本岛在线播放| 欧美黄片完整版在线观看 | 亚洲日本va午夜中文字幕一区| 亚洲综合精品久久久一区|