一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - PHP教程 - PHP利用Mysql鎖解決高并發(fā)的方法

PHP利用Mysql鎖解決高并發(fā)的方法

2019-09-09 11:04舊夢發(fā)癲 PHP教程

這篇文章主要介紹了PHP利用Mysql鎖解決高并發(fā)的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

前面寫過利用文件鎖來處理高并發(fā)的問題的,現(xiàn)在我們說另外一個(gè)處理方式,利用Mysql的鎖來解決高并發(fā)的問題

先看沒有利用事務(wù)的時(shí)候并發(fā)的后果

創(chuàng)建庫存管理表

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

創(chuàng)建訂單管理表

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);
  }
}

我們預(yù)置庫存是十個(gè),然后執(zhí)行ab測試查看結(jié)果

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個(gè),而庫存表的庫存也減到了-2,這顯然不符合實(shí)際邏輯的;

下面我們來看利用數(shù)據(jù)庫行鎖來解決這個(gè)問題

修改代碼如下

$pdo = new PDO('mysql:host=127.0.0.1;port=3306; dbname=test','root','123456');
$pdo->beginTransaction();//開啟事務(wù)
$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();//提交事務(wù)
    }
    else
    {
      $pdo->rollBack();//回滾
    }

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

查看結(jié)果

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鎖之后,對庫存進(jìn)行了有效的控制,很好的解決了第一段代碼里面,因?yàn)椴l(fā)引起的一些邏輯性的問題

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 息与子中文字幕bd | 美女用手扒开粉嫩的屁股 | 美女把腿开让我 | 呜嗯啊野战h呻吟男男双性 污小说在线阅读 | tube性睡觉hd | 亚洲女同一区二区 | 热99精品视频 | 国产区成人综合色在线 | 日本欧美不卡一区二区三区在线 | 国产成人激情 | 天天草视频| 黄a一级 | 亚洲视频一区在线播放 | 506rr亚洲欧美 | α片免费| 污斗罗大陆 | 变态女王麻麻小说在线阅读 | pregnantsexxx临盆孕妇 | 51国产午夜精品免费视频 | 成人福利在线观看 | 日本一本草久p | 性派对videofreeparty | 被夫上司强迫中文 | 日韩资源在线 | 久久精品国产久精国产果冻传媒 | 女暴露狂校园裸露小说 | 国产青青草 | 极品丝袜乱系列在线阅读 | 男人的j放进女人的p全黄 | 6080欧美一区二区三区四区 | 亚洲一成人毛片 | 精品视频一区二区观看 | 午夜精品免费 | 免费看h片的网站 | 国产白虎| 艾秋麻豆果冻剧传媒在线播放 | 亚洲天堂视频在线播放 | 乌克兰成人性色生活片 | 激情涩涩| 69成人影院 | bdsm中国精品调教 |