好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PHP利用Mysql鎖解決高并發的方法

PHP利用Mysql鎖解決高并發的方法

熱門標簽:電信外呼系統多少錢一個月 萍鄉商鋪地圖標注 太原400電話申請流程 宿州正規外呼系統軟件 神龍斗士電話機器人 企業400電話辦理多少費用 代理打電話機器人 合肥企業外呼系統線路 桂陽公司如何做地圖標注

前面寫過利用文件鎖來處理高并發的問題的,現在我們說另外一個處理方式,利用Mysql的鎖來解決高并發的問題

先看沒有利用事務的時候并發的后果

創建庫存管理表

CREATE TABLE `storage` (
 `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
 `number` int(11) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=latin1

創建訂單管理表

CREATE TABLE `order` (
 `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
 `number` int(11) DEFAULT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=34 DEFAULT CHARSET=latin1

測試代碼

$pdo = new PDO('mysql:host=127.0.0.1;port=3306; dbname=test','root','123456');
$sql="select `number` from storage where id=1 limit 1";
$res = $pdo->query($sql)->fetch();
$number = $res['number'];

if($number>0)
{
  $sql ="insert into `order` VALUES (null,$number)";
  
  $order_id = $pdo->query($sql);
  if($order_id)
  {

    $sql="update storage set `number`=`number`-1 WHERE id=1";
    $pdo->query($sql);
  }
}

我們預置庫存是十個,然后執行ab測試查看結果

mysql> select * from storage
  -> ;
+----+--------+
| id | number |
+----+--------+
| 1 |   -2 |
+----+--------+
1 row in set (0.00 sec)

mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 22 |   10 |
| 23 |   10 |
| 24 |   8 |
| 25 |   8 |
| 26 |   7 |
| 27 |   6 |
| 28 |   4 |
| 29 |   3 |
| 30 |   2 |
| 31 |   2 |
| 32 |   2 |
| 33 |   1 |
+----+--------+
12 rows in set (0.00 sec)

得到了訂單共有12個,而庫存表的庫存也減到了-2,這顯然不符合實際邏輯的;

下面我們來看利用數據庫行鎖來解決這個問題

修改代碼如下

$pdo = new PDO('mysql:host=127.0.0.1;port=3306; dbname=test','root','123456');
$pdo->beginTransaction();//開啟事務
$sql="select `number` from storage where id=1 for UPDATE ";//利用for update 開啟行鎖
$res = $pdo->query($sql)->fetch();
$number = $res['number'];

if($number>0)
{
  $sql ="insert into `order` VALUES (null,$number)";

  $order_id = $pdo->query($sql);
  if($order_id)
  {

    $sql="update storage set `number`=`number`-1 WHERE id=1";
    if($pdo->query($sql))
    {
      $pdo->commit();//提交事務
    }
    else
    {
      $pdo->rollBack();//回滾
    }

  }
  else
  {
    $pdo->rollBack();//回滾
  }
}

查看結果

mysql> select * from storage;
+----+--------+
| id | number |
+----+--------+
| 1 |   0 |
+----+------
--+
1 row in set (0.00 sec)

mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 1 |   10 |
| 2 |   9 |
| 3 |   8 |
| 4 |   7 |
| 5 |   6 |
| 6 |   5 |
| 7 |   4 |
| 8 |   3 |
| 9 |   2 |
| 10 |   1 |
+----+--------+
10 rows in set (0.00 sec)

很明顯在利用了mysql鎖之后,對庫存進行了有效的控制,很好的解決了第一段代碼里面,因為并發引起的一些邏輯性的問題

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • php多進程并發編程防止出現僵尸進程的方法分析
  • PHP高并發和大流量解決方案整理
  • PHP 并發場景的幾種解決方案
  • PHP下用Swoole實現Actor并發模型的方法
  • php多進程模擬并發事務產生的問題小結
  • PHP curl批處理及多請求并發實現方法分析
  • php curl批處理實現可控并發異步操作示例
  • PHP使用curl_multi實現并發請求的方法示例
  • 詳解PHP服務器如何在有限的資源里最大提升并發能力

標簽:綏化 辛集 白銀 廊坊 衡陽 太原 崇左 鄂州

巨人網絡通訊聲明:本文標題《PHP利用Mysql鎖解決高并發的方法》,本文關鍵詞  PHP,利用,Mysql,鎖,解決,高并發,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP利用Mysql鎖解決高并發的方法》相關的同類信息!
  • 本頁收集關于PHP利用Mysql鎖解決高并發的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 亚洲中文无码人aV在线69堂| 美女脱个精光视频秘?软件 | 国产丰满麻豆sexvideos| 男插女视频软件| 中美日韩在线网免费毛片视频 | 日本2和搜子同屋的日子在线观看| 美女的隐私秘密网站| 扒开?狂揉?喷水视频| 男舔女下面| 一个人在线免费观看www| 亚洲精品久久久久久久蜜桃臀 | 91香蕉国产线观看免费全集| 亚洲 自拍 另类 动图 gif| 爸爸说没人可以c| 乱码一线二线三线| 免费无码婬AAAA片在线漫画| 唾液と爱液の接吻无码| 秋霞免费乱理伦片在线观看| 轻点不要了| 美女露全乳无胸罩| 滛妇荡公在厨房引诱h| 无限流h| 96久热视频只有精品| 免费无码高潮又爽又刺激| 欧美在线完整高清观看| 成人毛片免费| 延迟の国产☆最新合集bt小伙| 免费九九视频| 国产精品99| 一级毛片免费观看久| 亚洲一区91精品网站| 18videosex 日本动漫| 欧洲vodafoneapn18| 欧美o| 国产精品天天看天天做夜夜爽| 和陌生人一起弄娇妻| 双腿被绑成m型调教play男男| 三浦理惠子无码寡妇| 欧美肮脏俱乐部1在线观看| 一级黄色a视频| 韩国r级无删减2023最新电影|