一区二区三区中文国产亚洲_另类视频区第一页_日韩精品免费视频_女人免费视频_国产综合精品久久亚洲

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > Laravel事務(wù)詳解

Laravel事務(wù)詳解

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-11-21 15:42:41 1700552561

Laravel是一個流行的PHP框架,它具有強大而豐富的數(shù)據(jù)庫操作功能。這些數(shù)據(jù)庫操作功能包括查詢構(gòu)建器和ORM(對象關(guān)系映射器),同時也包含了事務(wù)操作。在Laravel中,通過一系列的方法調(diào)用,可以輕松地開啟、提交和回滾數(shù)據(jù)庫事務(wù)。本文將詳細(xì)介紹Laravel事務(wù)相關(guān)的知識點,從理論到實踐,包涵代碼示例,力求讓大家深入理解Laravel事務(wù)的使用方法及其重要性。

一、事務(wù)概述

數(shù)據(jù)庫事務(wù)是一組數(shù)據(jù)庫操作,被看作是一個單一的工作單元,并且這些操作要么全部執(zhí)行成功要么全部回滾。對于需要在多個數(shù)據(jù)庫表中進行操作的復(fù)雜業(yè)務(wù)流程,使用數(shù)據(jù)庫事務(wù)可以保證業(yè)務(wù)的數(shù)據(jù)一致性。

Laravel的數(shù)據(jù)庫事務(wù)提供了一種簡單、方便的方法來實現(xiàn)這種原子性,可以保證在一系列數(shù)據(jù)庫操作失敗的情況下回滾到初始狀態(tài),以避免產(chǎn)生臟數(shù)據(jù)。

二、事務(wù)的使用方法

在Laravel中,開啟事務(wù)需要使用DB類的beginTransaction()方法,提交事務(wù)使用commit()方法,回滾事務(wù)使用rollback()方法。下面是一個基本的事務(wù)操作示例:


DB::beginTransaction();

try {
    // 數(shù)據(jù)庫操作1
    // 數(shù)據(jù)庫操作2
    // ...
    DB::commit();
} catch (\Exception $e) {
    DB::rollback();
    throw $e;
}

beginTransaction()方法用來啟動事務(wù);

try塊用來包含需要執(zhí)行的數(shù)據(jù)庫操作;

commit()方法用來提交事務(wù);

catch塊用來處理數(shù)據(jù)庫操作中異常情況,并通過rollback()方法回到事務(wù)初始狀態(tài)。

需要注意的是,Laravel中只有在包含在事務(wù)操作中的數(shù)據(jù)庫操作才能受到事務(wù)的保護。如果在事務(wù)之外執(zhí)行數(shù)據(jù)庫操作,那么這些操作是不會受到事務(wù)的影響。

三、事務(wù)的性質(zhì)

Laravel中的事務(wù)操作具有ACID特性(原子性、一致性、隔離性和持久性),它們將保證數(shù)據(jù)操作過程中的一系列問題引起的異常狀態(tài)。

原子性

事務(wù)中的所有操作將視為一個原子單元,要么全部執(zhí)行成功要么全部失敗。如果在任何時候發(fā)生錯誤,所有操作都將回滾到事務(wù)的開始狀態(tài)。這種特性保證了事務(wù)中的所有操作是不可分割和原子性的。

一致性

事務(wù)的執(zhí)行不會使數(shù)據(jù)庫處于不一致的狀態(tài)。在執(zhí)行事務(wù)時,它們將遵循數(shù)據(jù)庫模式的完整性約束。

隔離性

事務(wù)的隔離性指的是如果多個事務(wù)并發(fā)執(zhí)行,那么每一個事務(wù)對于其他事務(wù)執(zhí)行的數(shù)據(jù)操作是不可見的。這種策略確保了并發(fā)訪問時數(shù)據(jù)的一致性,避免了鎖等待。

持久性

一旦事務(wù)成功提交,它所做的更改將永久保存在數(shù)據(jù)庫中,并且即使在系統(tǒng)崩潰的情況下也是如此。

四、代碼示例

下面是一個實際的數(shù)據(jù)庫事務(wù)案例,演示了如何使用Laravel中的事務(wù)處理來確保用戶在存款和提款操作中擁有足夠的余額。


public function transfer(Request $request)
{
    // 獲取當(dāng)前用戶
    $user = Auth::user();

    // 獲取轉(zhuǎn)出賬號和轉(zhuǎn)入賬號
    $sender_account = $request->input('sender_account');
    $receiver_account = $request->input('receiver_account');

    // 獲取余額,并計算轉(zhuǎn)出金額
    $balance = $user->balance;
    $amount = $request->input('amount');
    $balance_after_transfer = $balance - $amount;

    // 檢查余額是否充足
    if ($balance_after_transfer < 0) {
        return response()->json([
            'message' => '您的余額不足'
        ], 400);
    }

    //開始事務(wù)
    DB::beginTransaction();

    try {
        // 計算轉(zhuǎn)出賬號余額,并插入轉(zhuǎn)賬記錄
        $sender_balance = DB::table('accounts')->where('account_number', $sender_account)->lockForUpdate()->value('balance');
        $sender_balance_after_transfer = $sender_balance - $amount;

        DB::table('accounts')->where('account_number', $sender_account)->update([
            'balance' => $sender_balance_after_transfer
        ]);

        DB::table('transactions')->insert([
            'account_number' => $sender_account,
            'type' => 'OUT',
            'amount' => $amount,
            'created_at' => Carbon::now()
        ]);

        // 計算轉(zhuǎn)入賬號余額,并插入轉(zhuǎn)入記錄
        $receiver_balance = DB::table('accounts')->where('account_number', $receiver_account)->lockForUpdate()->value('balance');
        $receiver_balance_after_transfer = $receiver_balance + $amount;

        DB::table('accounts')->where('account_number', $receiver_account)->update([
            'balance' => $receiver_balance_after_transfer
        ]);

        DB::table('transactions')->insert([
            'account_number' => $receiver_account,
            'type' => 'IN',
            'amount' => $amount,
            'created_at' => Carbon::now()
        ]);

        // 更新用戶余額
        $user->balance = $balance_after_transfer;
        $user->save();

        //提交事務(wù)
        DB::commit();

        return response()->json([
            'message' => '轉(zhuǎn)賬成功'
        ]);
    } catch (\Exception $e) {
        // 回滾事務(wù)
        DB::rollback();

        return response()->json([
            'message' => '服務(wù)器錯誤:' . $e->getMessage()
        ], 500);
    }
}

五、總結(jié)

本文介紹了Laravel事務(wù)的定義、使用方法、性質(zhì)和實際代碼示例。事務(wù)的使用可以確保復(fù)雜的數(shù)據(jù)庫操作在發(fā)生異常時可以回滾操作,來保證數(shù)據(jù)的完整性和一致性。希望本文可以幫助讀者了解Laravel事務(wù)的相關(guān)知識,并在實際開發(fā)中運用到事務(wù)操作中。

tags: latex縮進
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT