内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

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

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

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

具體如下:

1、背景:

現(xiàn)在有這樣的需求,插入數(shù)據(jù)時(shí),判斷test表有無(wú)username為‘mraz'的數(shù)據(jù),無(wú)則插入,有則提示“已插入”,目的就是想只插入一條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、一般少量請(qǐng)求的時(shí)候,程序邏輯不會(huì)有問(wèn)題。但是一旦高并發(fā)請(qǐng)求執(zhí)行的話,程序并沒(méi)有按預(yù)期執(zhí)行,會(huì)插入多條username為‘mraz'的記錄。

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

調(diào)整代碼后如下:

$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ā)請(qǐng)求該php腳本,查看數(shù)據(jù)庫(kù)會(huì)只有一條username為‘mraz'的記錄。達(dá)到程序執(zhí)行的預(yù)期結(jié)果~

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

網(wǎng)站名稱:如何解決PHP+MySQL高并發(fā)加鎖事務(wù)處理的問(wèn)題-創(chuàng)新互聯(lián)
網(wǎng)站地址:http://www.rwnh.cn/article48/cojjep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)、軟件開(kāi)發(fā)、企業(yè)建站、GoogleApp設(shè)計(jì)、App開(kāi)發(fā)

廣告

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

成都app開(kāi)發(fā)公司
永泰县| 同心县| 镇巴县| 绥中县| 黑山县| 修武县| 邵阳市| 桑植县| 庐江县| 卢湾区| 南乐县| 墨玉县| 伊宁县| 旬邑县| 抚州市| 连州市| 封开县| 蓬溪县| 岑溪市| 溆浦县| 子长县| 屏东县| 明水县| 茂名市| 鄂托克前旗| 博乐市| 行唐县| 巴彦淖尔市| 正阳县| 尼木县| 修武县| 新源县| 铜鼓县| 子长县| 靖远县| 洛浦县| 十堰市| 舞阳县| 佛坪县| 武安市| 木里|