首先在命令列1新增排他鎖定:下面測試下laravel裡的排他鎖定:然後再命令列2裡測試存取:
#可以看到,確實產生阻塞了,在命令列1裡commit結束後,指令行2裡也執行結果了。
所以,在命令列測試排他鎖是沒有問題的。
測試2:laravel控制器方法測試排他鎖定
兩個路由:1、先在命令列開啟事務新增排他鎖,同測試1裡的命令列1的操作;Route::get('/locktest1','LockController@LockTest1');
Route::get('/locktest2','LockController@LockTest2');
控制器中的LockTest1
和
LockTest2這兩個方法內容都一樣:
DB::beginTransaction(); // 开启事务 $goods = Goods::lockForUpdate()->first(); print_r($goods);
先存取路由/locktest1
,正常列印出數據,個人猜想此時事務沒有關閉,如果再有存取資料表的請求,應該是阻塞的。所以在此存取
/locktest2,結果還是正常列印出數據,為什麼沒有產生阻塞效果呢?
測試3:laravel控制器方法與命令列混合測試排他鎖定
然後訪問路由/locktest1,頁面一直運行中,說明查詢資料存在阻塞;最後命令列裡commit提交。
2、先訪問路由/locktest1
,正常列印出資料;然後在命令列開啟事務添加排他鎖,同測試1裡的命令列1的操作,發現正常查詢出數據,沒有阻塞;說明laravel的控制器方法裡的排他鎖操作確實沒有成功。
總結:為什麼laravel的lockForUpdate()沒有效果呢,還是說laravel控制器方法執行完畢後,會自動結束交易才導致沒有阻塞效果的?
於是,再做一次下面測試:,頁面在等待刷新;再訪問路由2將路由1的控制器方法裡加了一個sleep()方法:
/ locktest1DB::beginTransaction(); // 开启事务 $goods = Goods::lockForUpdate()->first(); print_r($goods);sleep(10);echo 'ddd';然後,存取路由1
/locktest2
,頁面也在等待刷新,說明應該是產生資料阻塞了,因為路由2中沒有sleep(),正常情況下是立即執行的。
/locktest1頁面列印出數據,同時
/locktest2頁面也列印出數據。
由此判斷,上面測試3沒有產生阻塞效果,應該是控制器的方法結束後,自動結束交易所導致的。
以上是個人分析,如有大神路過,還望留言告知一個正確答案!
更多程式相關知識,請造訪:程式設計教學! !
以上是分析laravel排他鎖lockForUpdate()使用問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Tocombatisolationandlonelinessinremotework,companiesshouldimplementregular,meaningfulinteractions,provideequalgrowthopportunities,andusetechnologyeffectively.1)Fostergenuineconnectionsthroughvirtualcoffeebreaksandpersonalsharing.2)Ensureremoteworkers

laravelispularfullull-stackDevelopmentBecapeitOffersAsAseAseAseAseBlendOfbackendEdpoperandPowerandForterFlexibility.1)ITSbackEndCapaPabilities,sightifyDatabaseInteractions.2)thebladeTemplatingEngingEngineAllolowsLows

選擇視頻會議平台的關鍵因素包括用戶界面、安全性和功能。 1)用戶界面應直觀,如Zoom。 2)安全性需重視,MicrosoftTeams提供端到端加密。 3)功能需匹配需求,GoogleMeet適合簡短會議,CiscoWebex提供高級協作工具。

最新版本的Laravel10與MySQL5.7及以上、PostgreSQL9.6及以上、SQLite3.8.8及以上、SQLServer2017及以上兼容。這些版本選擇是因為它們支持Laravel的ORM功能,如MySQL5.7的JSON數據類型,提升了查詢和存儲效率。

Laravelisanexcellentchoiceforfull-stackdevelopmentduetoitsrobustfeaturesandeaseofuse.1)ItsimplifiescomplextaskswithitsmodernPHPsyntaxandtoolslikeBladeforfront-endandEloquentORMforback-end.2)Laravel'secosystem,includingLaravelMixandArtisan,enhancespro

Laravel10,releasedonFebruary7,2023,isthelatestversion.Itfeatures:1)Improvederrorhandlingwithanewreportmethodintheexceptionhandler,2)EnhancedsupportforPHP8.1featureslikeenums,and3)AnewLaravel\Promptspackageforinteractivecommand-lineprompts.

thelatestlaravelververversionenhancesdevelopmentwith:1)簡化的inimpliticmodelbinding,2)增強EnhancedeloquentcapabibilitionswithNewqueryMethods和3)改善了supportorfortormodernphpfortornphpforternphpfeatureserslikenamedargenamedArgonedArgonsemandArgoctess,makecodingMoreftermeforefterMealiteFficeAndEnjoyaigaigaigaigaigaiganigaborabilyaboipaigyAndenjoyaigobyabory。

你可以在laravel.com/docs找到最新Laravel版本的發布說明。 1)發布說明提供了新功能、錯誤修復和改進的詳細信息。 2)它們包含示例和解釋,幫助理解新功能的應用。 3)注意新功能的潛在復雜性和向後兼容性問題。 4)定期審查發布說明可以保持更新並激發創新。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

WebStorm Mac版
好用的JavaScript開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能