91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

laravel怎么解決庫存超出問題

發布時間:2022-12-08 17:54:00 來源:億速云 閱讀:169 作者:iii 欄目:編程語言

本篇內容介紹了“laravel怎么解決庫存超出問題”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

數據庫字段

laravel怎么解決庫存超出問題

1. 錯誤的示范

2021-06-08 10:57:59
     * @return string
     */
    function test1()
    {

        //商品id
        $id = request()->input('id');

        $product = Product::where('id', $id)->firstOrFail();

        if ($product->num <= 0) {

            return "賣光啦!!";
        }

        //庫存減1
        $product->decrement('num');

        return "success";

    }

使用 go 模擬并發

package main

import (
    "fmt"
    "github.com/PeterYangs/tools/http"
    "sync"
)

func main() {

    client := http.Client()

    wait := sync.WaitGroup{}

    for i := 0; i < 50; i++ {

        wait.Add(1)

        go func(w *sync.WaitGroup) {

            defer w.Done()

            res, _ := client.Request().GetToString("http://www.api/test1?id=1")

            fmt.Println(res)

        }(&wait)

    }

    wait.Wait()

}

在數據庫中查看庫存

laravel怎么解決庫存超出問題

庫存已超出

2.redis 原子鎖

2021-06-08 11:00:31
     */
    function test2()
    {
        //商品id
        $id = request()->input('id');

        $lock = \Cache::lock("product_" . $id, 10);

        try {

            //最多等待5秒,5秒后未獲取到鎖,則拋出異常
            $lock->block(5);

            $product = Product::where('id', $id)->firstOrFail();

            if ($product->num <= 0) {

                return "賣光啦!!";
            }
            //庫存減1
            $product->decrement('num');

            return 'success';

        }catch (LockTimeoutException $e) {

            return '當前人數過多';

        } finally {

            optional($lock)->release();
        }
    }

庫存正常

laravel怎么解決庫存超出問題

3.mysql 悲觀鎖

2021-06-08 11:00:47
     */
    function test3()
    {

        //商品id
        $id = request()->input('id');

        try {
            \DB::beginTransaction();
            $product = Product::where('id', $id)->lockForUpdate()->first();

            if ($product->num <= 0) {

                return "賣光啦!!";
            }

            //庫存減1
            $product->decrement('num');

            \DB::commit();

            return "success";

        } catch (\Exception $exception) {

        }

    }

庫存正常

laravel怎么解決庫存超出問題

4.mysql 樂觀鎖

2021-06-08 11:00:47
     */
    function test4()
    {

        //商品id
        $id = request()->input('id');

        $product = Product::where('id', $id)->first();

        if ($product->num <= 0) {

            return "賣光啦!!";
        }

        //修改前檢查庫存和之前是否一致,不一致說明已經有變動,則放棄更改
        $res = \DB::update('UPDATE `product`, [$id, $product->num]);

        if (!$res) {

            return '當前人數過多';

        }

        return 'success';


    }

庫存正常

laravel怎么解決庫存超出問題

優化樂觀鎖

修改庫存的 sql 修改為

\DB::update('UPDATE `product`, [$id]);

5.redis 存儲庫存

2021-06-15 15:18:31
     * @return string
     */
    function test5()
    {

        //商品id
        $id = request()->input('id');


        $num = Redis::command('get', ['product_' . $id]);


        if ($num <= 0) {

            return "賣完啦!";
        }

        //減庫存
        $re = Redis::command('decrby', ['product_' . $id, 1]);


        //減多了回滾
        if ($re < 0) {

            Redis::command('incrby', ['product_' . $id, 1]);


            return "賣完啦!";

        }

        return 'success';

    }

“laravel怎么解決庫存超出問題”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

大关县| 锡林浩特市| 临沧市| 江都市| 平塘县| 西昌市| 古田县| 鲜城| 绵阳市| 益阳市| 丹巴县| 长海县| 封丘县| 泸水县| 沛县| 芦溪县| 修文县| 泽普县| 高清| 大石桥市| 卓资县| 新竹市| 乌拉特前旗| 惠州市| 玉山县| 南京市| 祁门县| 灵台县| 阿瓦提县| 长寿区| 巨野县| 霍邱县| 平陆县| 台中市| 章丘市| 江陵县| 柘城县| 安泽县| 台州市| 宁夏| 平遥县|