成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

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

Coly / 1028人閱讀

摘要:前面寫過利用文件鎖來處理高并發(fā)的問題的,現(xiàn)在我們說另外一個處理方式,利用的鎖來解決高并發(fā)的問題先看沒有利用事務(wù)的時候并發(fā)的后果創(chuàng)建庫存管理表創(chuàng)建訂單管理表測試代碼我們預(yù)置庫存是十個,然后執(zhí)行測試查看結(jié)果

前面寫過利用文件鎖來處理高并發(fā)的問題的,現(xiàn)在我們說另外一個處理方式,利用Mysql的鎖來解決高并發(fā)的問題
先看沒有利用事務(wù)的時候并發(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ù)置庫存是十個,然后執(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個,而庫存表的庫存也減到了-2,這顯然不符合實際邏輯的;

下面我們來看利用數(shù)據(jù)庫行鎖來解決這個問題
修改代碼如下
$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)行了有效的控制,很好的解決了第一段代碼里面,因為并發(fā)引起的一些邏輯性的問題

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/29399.html

相關(guān)文章

  • 秒殺系統(tǒng)優(yōu)化方案之緩存、隊列、設(shè)計思路

    摘要:一為什么難秒殺系統(tǒng)難做的原因庫存只有一份,所有人會在集中的時間讀和寫這些數(shù)據(jù)。又例如搶票,亦與秒殺類似,瞬時流量更甚。 一、為什么難 ????秒殺系統(tǒng)難做的原因:庫存只有一份,所有人會在集中的時間讀和寫這些數(shù)據(jù)。例如小米手機(jī)每周二的秒殺,可能手機(jī)只有1萬部,但瞬時進(jìn)入的流量可能是幾百幾千萬。又例如12306搶票,亦與秒殺類似,瞬時流量更甚。 主要需要解決的問題有兩個: 高并發(fā)對數(shù)據(jù)庫...

    dinfer 評論0 收藏0
  • Mysql機(jī)制與PHP文件處理并發(fā)簡單思路

    摘要:以購買商品舉例從數(shù)據(jù)庫獲取庫存的數(shù)量。這里暫時就不測試了,下面會針對并發(fā)的處理給出測試結(jié)果。第二種方案,使用的文件鎖。特點(diǎn)當(dāng)調(diào)用鎖一個文件時,如果沒有獲取鎖,直接返回,不會出現(xiàn)阻塞。的表鎖和的文件鎖在應(yīng)對并發(fā)數(shù)量上也有差別,自己可以多測試。 以購買商品舉例: ① 從數(shù)據(jù)庫獲取庫存的數(shù)量。② 檢查一下庫存的數(shù)量是否充足。③ 庫存的數(shù)量減去買家購買的數(shù)量(以每個用戶購買一個為例)。④ 最后...

    sunsmell 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<