您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關ThinkPHP6中事務的操作示例的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
一、先說說使用場景。
假設我需要給朋友轉賬1000元錢,正常的業務邏輯是:
1、銀行從我的賬戶中扣除1000元
2、銀行給朋友賬戶加上1000元。
如果一切順利,則轉賬成功!
那么問題來了,如果我不小心把銀行賬戶輸錯,導致銀行查找不到我輸入的銀行賬戶,但是這個時候錢已經從我的賬戶扣除了,如何處理呢?
我們生活中經常說“如果錢打不過去,銀行會退回來的”,就是這個意思。
2、事務操作定義。
那么通過上面的例子,我們理解下到底什么是事務操作,事務指的是邏輯上的一組操作,組成這組操作的各個單元要么全都成功,要么全都失敗。
就如上面的打錢例子,要么打錢成功,如果不成功,需要把我的錢退回來,也就是返回到初始狀態,也叫做“回滾”。
3、ThinkPHP6中的事務操作。
我們理解了事務操作的使用場景,那么在ThinkPHP6中如何使用呢?
Db::transaction(function () { Db::table('think_user')->insert(['name'=>'aaa']); Db::table('think_user')->delete(1); });
我們看上面的例子,只有當我們插入記錄成功的時候才會做刪除操作,如果插入不成功,不會做刪除操作。
比如我們故意寫錯一個字段name1,數據表中沒有name1該字段,插入程序不會執行成功,那么下面的刪除語句沒有問題,但是他依然不會執行。
除此之外,我們還可以手動控制事務。看下面代碼:
// 啟動事務 Db::startTrans(); try { Db::table('think_user')->find(1); Db::table('think_user')->delete(1); // 提交事務 Db::commit(); } catch (\Exception $e) { // 回滾事務 Db::rollback(); }
感謝各位的閱讀!關于“ThinkPHP6中事務的操作示例”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。