婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 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鎖解決高并發的方法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美一区二区三区公司| 中文字幕免费不卡| 久久国产精品无码网站| 精品乱码亚洲一区二区不卡| 韩国视频一区二区| 国产欧美日韩久久| 91色在线porny| 五月激情丁香一区二区三区| 日韩欧美国产电影| 国产999精品久久久久久| 中文字幕在线观看不卡视频| 在线观看网站黄不卡| 免费在线成人网| 国产精品一区二区免费不卡| 中文字幕精品一区二区精品绿巨人| 色综合久久88色综合天天6| 香蕉成人啪国产精品视频综合网| 日韩欧美国产三级电影视频| 国产福利一区二区三区| 成人欧美一区二区三区1314| 精品视频999| 国精产品一区一区三区mba视频| 综合网在线视频| 91精品国产欧美一区二区| 丰满岳乱妇一区二区三区 | 日韩欧美的一区| 成人一区二区三区视频| 亚洲一级不卡视频| 久久众筹精品私拍模特| 色激情天天射综合网| 九色综合国产一区二区三区| 综合网在线视频| 日韩欧美国产一区二区在线播放 | 日韩精品福利网| 国产午夜亚洲精品不卡| 在线视频欧美精品| 国产乱国产乱300精品| 亚洲综合男人的天堂| 2021久久国产精品不只是精品| 色婷婷综合久久久久中文一区二区| 蜜桃免费网站一区二区三区| 中文字幕一区二区三| 日韩欧美一区二区久久婷婷| 99精品久久免费看蜜臀剧情介绍| 免费精品视频在线| 亚洲日本在线天堂| 精品人在线二区三区| 在线观看亚洲精品| 成人小视频免费观看| 欧美a级理论片| 亚洲女同一区二区| 国产亚洲一本大道中文在线| 91麻豆精品国产自产在线观看一区| 亚洲欧美一区二区不卡| 久久先锋影音av| 3d动漫精品啪啪1区2区免费| 99久久久精品| 国产一区二区精品久久| 日本怡春院一区二区| 一区二区在线免费| 中文字幕精品三区| 欧美精品一区二区三区很污很色的 | 成人性生交大合| 麻豆精品在线观看| 午夜日韩在线观看| 亚洲欧美偷拍卡通变态| 国产亚洲精品资源在线26u| 欧美一区二区观看视频| 欧美在线不卡一区| 97se狠狠狠综合亚洲狠狠| 国产精品一区二区久久精品爱涩| 蜜臀国产一区二区三区在线播放| 一级特黄大欧美久久久| 在线这里只有精品| 成人美女视频在线观看18| 韩国精品一区二区| 毛片不卡一区二区| 日韩成人一级片| 午夜精品一区二区三区免费视频| 亚洲精品高清视频在线观看| 国产精品视频麻豆| 久久精品视频一区二区三区| 精品精品国产高清a毛片牛牛| 欧美日韩不卡一区| 欧美日韩国产免费| 欧美午夜在线一二页| 在线免费观看日本欧美| 99久久国产免费看| 成+人+亚洲+综合天堂| 成人免费视频一区二区| 国产精品资源在线| 国产一区中文字幕| 久久成人综合网| 久久99久久99| 久久99精品一区二区三区三区| 欧美aaaaaa午夜精品| 美女高潮久久久| 久久男人中文字幕资源站| 精品国产一区二区三区久久久蜜月| 日韩精品最新网址| 精品久久国产字幕高潮| 久久伊人中文字幕| 久久影院午夜片一区| 久久久www免费人成精品| 国产三级欧美三级| 国产精品麻豆一区二区| 最新日韩av在线| 亚洲精品亚洲人成人网在线播放| 亚洲乱码日产精品bd| 亚洲综合网站在线观看| 亚洲人快播电影网| 亚洲国产精品一区二区www| 午夜视频久久久久久| 美女视频一区在线观看| 国产乱子伦一区二区三区国色天香| 国产精品一区二区久久精品爱涩| 国产成人免费视频网站| 不卡影院免费观看| 欧洲一区二区三区在线| 欧美色图一区二区三区| 8v天堂国产在线一区二区| 国产一区二区三区电影在线观看 | 蜜臀久久99精品久久久久宅男| 免费日韩伦理电影| 极品少妇xxxx偷拍精品少妇| 国产91综合网| 一本久久a久久免费精品不卡| 欧美日韩国产电影| 精品国产a毛片| 国产精品国产三级国产普通话三级| 亚洲少妇中出一区| 午夜精品一区二区三区电影天堂| 美腿丝袜亚洲综合| 国产不卡在线播放| 欧美在线短视频| 欧美成人乱码一区二区三区| 国产三级精品三级| 一区二区三国产精华液| 男女男精品视频| 成人午夜看片网址| 欧美手机在线视频| 日韩精品专区在线影院观看| 国产精品私房写真福利视频| 欧美精品精品一区| 久久久精品日韩欧美| 夜夜揉揉日日人人青青一国产精品| 青青草国产精品97视觉盛宴| 国产成人av在线影院| 欧美亚洲丝袜传媒另类| 久久综合精品国产一区二区三区| 日韩理论片网站| 日本va欧美va精品| 成人av影视在线观看| 在线不卡a资源高清| 国产嫩草影院久久久久| 亚洲国产精品自拍| 国产精品一区专区| 在线视频你懂得一区二区三区| 欧美α欧美αv大片| 亚洲精品老司机| 狠狠色狠狠色综合| 欧美在线观看你懂的| 久久精品亚洲精品国产欧美kt∨| 亚洲综合一二区| 国产99久久久国产精品| 欧美精品久久99久久在免费线 | 亚洲午夜久久久久中文字幕久| 国产呦萝稀缺另类资源| 欧美三级电影网站| 91亚洲国产成人精品一区二区三 | 国产精品久久久一区麻豆最新章节| 亚洲成人综合网站| 粉嫩一区二区三区在线看| 欧美日韩国产大片| |精品福利一区二区三区| 精品亚洲aⅴ乱码一区二区三区| 在线观看91精品国产入口| 久久品道一品道久久精品| 视频在线在亚洲| 色婷婷亚洲综合| 国产女主播一区| 久久精品久久精品| 精品视频在线免费| 亚洲婷婷综合色高清在线| 精品亚洲porn| 51午夜精品国产| 亚洲精品国产精华液| 高清不卡一区二区| 欧美成人女星排名| 午夜精品久久久久久久| 色婷婷综合在线| 国产精品国产自产拍高清av王其| 久久成人免费网| 理论电影国产精品| 欧美在线高清视频| 日韩理论片一区二区| 成人小视频在线| 久久久综合视频| 久久99精品视频| 欧美一区中文字幕|