1.官方手冊是這樣介紹的:
想要在一個數據庫事務中運行一連串操作,可以使用DB門面的transaction方法,如果事務閉包中拋出異常,事務將會自動回滾。如果閉包執行成功,事務將會自動提交。使用transaction方法時不需要擔心手動回滾或提交:
1
2
3
4
|
DB::transaction( function () { DB::table( 'users' )->update([ 'votes' => 1]); DB::table( 'posts' )-> delete (); }); |
手動使用事務
如果你想要手動開始事務從而對回滾和提交有一個完整的控制,可以使用DB門面的beginTransaction方法:
1
|
DB::beginTransaction(); |
你可以通過rollBack方法回滾事務:
1
|
DB::rollBack(); |
最后,你可以通過commit方法提交事務:
1
|
DB::commit(); |
注意:使用DB門面的事務方法還可以用于控制查詢構建器和 Eloquent ORM 的事務。
2.具體是這樣使用的:
1
2
3
4
5
6
7
8
|
use Illuminate\Support\Facades\DB; //開啟事務 DB::beginTransaction(); try { //中間邏輯代碼 DB::commit(); } catch (\Exception $e ) { //接收異常處理并回滾 DB::rollBack(); } |
以上這篇laravel5 Eloquent 實現事務方式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/sanbingyutuoniao123/article/details/54342086