這篇文章帶給大家的內(nèi)容是關(guān)於Yii2開(kāi)發(fā): 如何用類(lèi)似閉包的方式來(lái)封裝事務(wù),有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)你有所幫助。
在控制器中執(zhí)行事務(wù)的時(shí)候,一般的程式碼如下:
$transaction?=?Yii::$app->db->beginTransaction(); try?{ ????//一些業(yè)務(wù)代碼 ????$transaction->commit(); }?catch?(\Exception?$e)?{ ????$transaction->rollBack(); ????throw?$e; }
於是我在想,這個(gè)程式碼結(jié)構(gòu),只有//一些業(yè)務(wù)程式碼這一部分是不一樣,卻要重複很多遍,這一不是很冗餘嗎?而且 不!好!看! ,於是我試著尋找解決方法,一開(kāi)始在stackflow找到一個(gè)類(lèi)似的提問(wèn),有方案是在model裡做封裝,但是這樣做有一定問(wèn)題,如產(chǎn)生嵌套事??務(wù)等,有興趣的可以點(diǎn)擊這裡查看該問(wèn)答。
我們的Yii框架給了一個(gè)方法transaction,乍看之下好像不能解決傳參的問(wèn)題,我們先不管,往下看,該方法調(diào)用方式如下:
Yii::$app->db->transaction(function()?{ ????//一些業(yè)務(wù)代碼 });
我們來(lái)看這個(gè)方法的原始碼
/** ?*?Executes?callback?provided?in?a?transaction. ?* ?*?@param?callable?$callback?a?valid?PHP?callback?that?performs?the?job.?Accepts?connection?instance?as?parameter. ?*?@param?string|null?$isolationLevel?The?isolation?level?to?use?for?this?transaction. ?*?See?[[Transaction::begin()]]?for?details. ?*?@throws?\Exception|\Throwable?if?there?is?any?exception?during?query.?In?this?case?the?transaction?will?be?rolled?back. ?*?@return?mixed?result?of?callback?function ?*/ public?function?transaction(callable?$callback,?$isolationLevel?=?null) { ????$transaction?=?$this->beginTransaction($isolationLevel); ????$level?=?$transaction->level; ????try?{ ????????$result?=?call_user_func($callback,?$this); ????????if?($transaction->isActive?&&?$transaction->level?===?$level)?{ ????????????$transaction->commit(); ????????} ????}?catch?(\Exception?$e)?{ ????????$this->rollbackTransactionOnLevel($transaction,?$level); ????????throw?$e; ????}?catch?(\Throwable?$e)?{ ????????$this->rollbackTransactionOnLevel($transaction,?$level); ????????throw?$e; ????} ????return?$result; }
這個(gè)方法接受一個(gè)回呼函數(shù)和事務(wù)的隔離級(jí)別,
從這裡我們看出,這個(gè)方法雖然解決重複程式碼,卻還有幾個(gè)問(wèn)題沒(méi)有解決:
第一,這個(gè)方法拋出的例外我們需要在接收外面處理,我們不可能直接拋出,這樣對(duì)客戶(hù)端很不友善。
第二:沒(méi)有記錄日誌的行為,即使出了問(wèn)題也不容易排除。
第三:其實(shí)還是第一個(gè)問(wèn)題,如果我們需要對(duì)每個(gè)例外做處理,在transaction方法外再嵌套一層try...catch...,那麼和沒(méi)有封裝好像沒(méi)什麼差別?
根據(jù)方法可擴(kuò)展不可修改的原則,我們應(yīng)該在自己公共方法裡對(duì)這個(gè)方法進(jìn)行重載,重載程式碼如下:
public?static?function?TransactionExecute(callable?$function,$level=null) { ????try{ ????????\Yii::$app->db->transaction($function,$level); }catch?(\Exception?$e){ ????????//記錄日志 ????????\Yii::error($e->getMessage()); ????????//這里可以理解成拋出自定義的異常類(lèi)。 ????????(new?self())->returnWayTip(1004,?'trans異常錯(cuò)誤'); ????} }
然後回到如何傳參的問(wèn)題,我們可以使用閉包,貼上一段偽代碼,如下:
//執(zhí)行事務(wù) PublicFunction::TransactionExecute(function?()?use?($token_reward,?$reward_info)?{ ????????//業(yè)務(wù)代碼 ????????$token_reward->save(0); ????MsgHelper::send($reward_info['post_id'],?MsgHelper::SOMEONE_FINISH_REWARD,?$reward_info); ????});
相關(guān)推薦:
php中的系統(tǒng)設(shè)定有哪些? php中常用系統(tǒng)設(shè)定的小結(jié)(附程式碼)
php如何產(chǎn)生json? php生成json的方法程式碼
以上是Yii2開(kāi)發(fā): 如何用類(lèi)似閉包的方式來(lái)封裝事務(wù)的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

熱AI工具

Undress AI Tool
免費(fèi)脫衣圖片

Undresser.AI Undress
人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門(mén)文章

熱工具

記事本++7.3.1
好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強(qiáng)大的PHP整合開(kāi)發(fā)環(huán)境

Dreamweaver CS6
視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版
神級(jí)程式碼編輯軟體(SublimeText3)

用戶(hù)語(yǔ)音輸入通過(guò)前端JavaScript的MediaRecorderAPI捕獲並發(fā)送至PHP後端;2.PHP將音頻保存為臨時(shí)文件後調(diào)用STTAPI(如Google或百度語(yǔ)音識(shí)別)轉(zhuǎn)換為文本;3.PHP將文本發(fā)送至AI服務(wù)(如OpenAIGPT)獲取智能回復(fù);4.PHP再調(diào)用TTSAPI(如百度或Google語(yǔ)音合成)將回復(fù)轉(zhuǎn)為語(yǔ)音文件;5.PHP將語(yǔ)音文件流式返回前端播放,完成交互。整個(gè)流程由PHP主導(dǎo)數(shù)據(jù)流轉(zhuǎn)與錯(cuò)誤處理,確保各環(huán)節(jié)無(wú)縫銜接。

在PHP中搭建社交分享功能的核心方法是通過(guò)動(dòng)態(tài)生成符合各平臺(tái)要求的分享鏈接。 1.首先獲取當(dāng)前頁(yè)面或指定的URL及文章信息;2.使用urlencode對(duì)參數(shù)進(jìn)行編碼;3.根據(jù)各平臺(tái)協(xié)議拼接生成分享鏈接;4.在前端展示鏈接供用戶(hù)點(diǎn)擊分享;5.動(dòng)態(tài)生成頁(yè)面OG標(biāo)籤優(yōu)化分享內(nèi)容展示;6.務(wù)必對(duì)用戶(hù)輸入進(jìn)行轉(zhuǎn)義以防止XSS攻擊。該方法無(wú)需複雜認(rèn)證,維護(hù)成本低,適用於大多數(shù)內(nèi)容分享需求。

要實(shí)現(xiàn)PHP結(jié)合AI進(jìn)行文本糾錯(cuò)與語(yǔ)法優(yōu)化,需按以下步驟操作:1.選擇適合的AI模型或API,如百度、騰訊API或開(kāi)源NLP庫(kù);2.通過(guò)PHP的curl或Guzzle調(diào)用API並處理返回結(jié)果;3.在應(yīng)用中展示糾錯(cuò)信息並允許用戶(hù)選擇是否採(cǎi)納;4.使用php-l和PHP_CodeSniffer進(jìn)行語(yǔ)法檢測(cè)與代碼優(yōu)化;5.持續(xù)收集反饋並更新模型或規(guī)則以提升效果。選擇AIAPI時(shí)應(yīng)重點(diǎn)評(píng)估準(zhǔn)確率、響應(yīng)速度、價(jià)格及對(duì)PHP的支持。代碼優(yōu)化應(yīng)遵循PSR規(guī)範(fàn)、合理使用緩存、避免循環(huán)查詢(xún)、定期審查代碼,並藉助X

1.評(píng)論系統(tǒng)商業(yè)價(jià)值最大化需結(jié)合原生廣告精準(zhǔn)投放、用戶(hù)付費(fèi)增值服務(wù)(如上傳圖片、評(píng)論置頂)、基於評(píng)論質(zhì)量的影響力激勵(lì)機(jī)制及合規(guī)匿名數(shù)據(jù)洞察變現(xiàn);2.審核策略應(yīng)採(cǎi)用前置審核 動(dòng)態(tài)關(guān)鍵詞過(guò)濾 用戶(hù)舉報(bào)機(jī)制組合,輔以評(píng)論質(zhì)量評(píng)分實(shí)現(xiàn)內(nèi)容分級(jí)曝光;3.防刷需構(gòu)建多層防禦:reCAPTCHAv3無(wú)感驗(yàn)證、Honeypot蜜罐字段識(shí)別機(jī)器人、IP與時(shí)間戳頻率限制阻止灌水、內(nèi)容模式識(shí)別標(biāo)記可疑評(píng)論,持續(xù)迭代應(yīng)對(duì)攻擊。

PHP通過(guò)數(shù)據(jù)庫(kù)事務(wù)與FORUPDATE行鎖確保庫(kù)存扣減原子性,防止高並發(fā)超賣(mài);2.多平臺(tái)庫(kù)存一致性需依賴(lài)中心化管理與事件驅(qū)動(dòng)同步,結(jié)合API/Webhook通知及消息隊(duì)列保障數(shù)據(jù)可靠傳遞;3.報(bào)警機(jī)制應(yīng)分場(chǎng)景設(shè)置低庫(kù)存、零/負(fù)庫(kù)存、滯銷(xiāo)、補(bǔ)貨週期和異常波動(dòng)策略,並按緊急程度選擇釘釘、短信或郵件通知責(zé)任人,且報(bào)警信息需完整明確,以實(shí)現(xiàn)業(yè)務(wù)適配與快速響應(yīng)。

PHPisstillrelevantinmodernenterpriseenvironments.1.ModernPHP(7.xand8.x)offersperformancegains,stricttyping,JITcompilation,andmodernsyntax,makingitsuitableforlarge-scaleapplications.2.PHPintegrateseffectivelyinhybridarchitectures,servingasanAPIgateway

Homebrew在Mac環(huán)境搭建中的核心作用是簡(jiǎn)化軟件安裝與管理。 1.Homebrew自動(dòng)處理依賴(lài)關(guān)係,將復(fù)雜的編譯安裝流程封裝為簡(jiǎn)單命令;2.提供統(tǒng)一的軟件包生態(tài),確保軟件安裝位置與配置標(biāo)準(zhǔn)化;3.集成服務(wù)管理功能,通過(guò)brewservices可便捷啟動(dòng)、停止服務(wù);4.便於軟件升級(jí)與維護(hù),提升系統(tǒng)安全性與功能性。

避免N 1查詢(xún)問(wèn)題,通過(guò)提前加載關(guān)聯(lián)數(shù)據(jù)來(lái)減少數(shù)據(jù)庫(kù)查詢(xún)次數(shù);2.僅選擇所需字段,避免加載完整實(shí)體以節(jié)省內(nèi)存和帶寬;3.合理使用緩存策略,如Doctrine的二級(jí)緩存或Redis緩存高頻查詢(xún)結(jié)果;4.優(yōu)化實(shí)體生命週期,定期調(diào)用clear()釋放內(nèi)存以防止內(nèi)存溢出;5.確保數(shù)據(jù)庫(kù)索引存在並分析生成的SQL語(yǔ)句以避免低效查詢(xún);6.在無(wú)需跟蹤變更的場(chǎng)景下禁用自動(dòng)變更跟蹤,改用數(shù)組或輕量模式提升性能。正確使用ORM需結(jié)合SQL監(jiān)控、緩存、批量處理和適當(dāng)優(yōu)化,在保持開(kāi)發(fā)效率的同時(shí)確保應(yīng)用性能。
