一、先說說使用場景。
假設(shè)我需要給朋友轉(zhuǎn)賬1000元錢,正常的業(yè)務(wù)邏輯是:
1、銀行從我的賬戶中扣除1000元
2、銀行給朋友賬戶加上1000元。
如果一切順利,則轉(zhuǎn)賬成功!
那么問題來了,如果我不小心把銀行賬戶輸錯,導(dǎo)致銀行查找不到我輸入的銀行賬戶,但是這個時候錢已經(jīng)從我的賬戶扣除了,如何處理呢?
我們生活中經(jīng)常說“如果錢打不過去,銀行會退回來的”,就是這個意思。
2、事務(wù)操作定義。
那么通過上面的例子,我們理解下到底什么是事務(wù)操作,事務(wù)指的是邏輯上的一組操作,組成這組操作的各個單元要么全都成功,要么全都失敗。
就如上面的打錢例子,要么打錢成功,如果不成功,需要把我的錢退回來,也就是返回到初始狀態(tài),也叫做“回滾”。
3、ThinkPHP6中的事務(wù)操作。
我們理解了事務(wù)操作的使用場景,那么在ThinkPHP6中如何使用呢?
Db::transaction(function () { Db::table('think_user')->insert(['name'=>'aaa']); Db::table('think_user')->delete(1); });
我們看上面的例子,只有當(dāng)我們插入記錄成功的時候才會做刪除操作,如果插入不成功,不會做刪除操作。
比如我們故意寫錯一個字段name1,數(shù)據(jù)表中沒有name1該字段,插入程序不會執(zhí)行成功,那么下面的刪除語句沒有問題,但是他依然不會執(zhí)行。
除此之外,我們還可以手動控制事務(wù)。看下面代碼:
// 啟動事務(wù) Db::startTrans(); try { Db::table('think_user')->find(1); Db::table('think_user')->delete(1); // 提交事務(wù) Db::commit(); } catch (Exception $e) { // 回滾事務(wù) Db::rollback(); }
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com