小編給大家分享一下laravel中Pivot模型ID的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)建站IDC提供業(yè)務:南充服務器托管,成都服務器租用,南充服務器托管,重慶服務器租用等四川省內主機托管與主機租用業(yè)務;數據中心含:雙線機房,BGP機房,電信機房,移動機房,聯(lián)通機房。Laravel 是一套簡潔、優(yōu)雅的PHP Web開發(fā)框架。它可以讓你從面條一樣雜亂的代碼中解脫出來;它可以幫你構建一個完美的網絡APP,而且每行代碼都可以簡潔、富于表達力。
項目環(huán)境
老系統(tǒng)(linux + laravel5.6 + php7.2 + mysql5.7)
升級后新系統(tǒng)(linux +laravel5.8 + php7.2 + mysql5.7)
只單純升級了laravel框架版本,并無升級其他相關服務依賴.
但是卻出現(xiàn)大量的SQL執(zhí)行錯誤,異常監(jiān)控如下:
分析過程
導致這段服務出錯的是這樣的一段業(yè)務邏輯,下面通過一段demo來模擬.
$pivot = UserRole::firstOrCreate([ 'user_id' => 3, 'role_id' => 3, ]); $this->addRoleHistory($user,$pivot->id); dd($pivot->id);
在laravel5.6版本中這段代碼運行起來毫無問題,但升級到5.8版本中就會引發(fā)大量的SQL執(zhí)行錯誤,就像下面這樣.
laravel5.6: dd($pivot->id); //10002 laravel5.8: dd($pivot->id); //null
在5.6中保存中的數據還能正常獲取到ID,在5.8中怎么就不行了呢,于是馬上去查看了laravel5.8的發(fā)行說明,也沒有發(fā)現(xiàn)對Pivot模型取消獲取自增ID的改動,于是開始進行5.8源碼查閱。。。
首先對5.6和5.8的firstOrCreate函數進行了對比,發(fā)現(xiàn)無改動,代碼邏輯執(zhí)行無誤。
然后繼續(xù)翻閱model->save()函數的代碼
,發(fā)現(xiàn)不存在的數據是通過insertAndSetId該函數插入數據并設置主鍵ID
但insertAndSetId函數又是通過incrementing這樣的一個成員屬性來控制的,屬性的默認值是true
當這個屬性變更時就不會執(zhí)行者一步驟,難道這個成員屬性在被操作過了?
于是立馬查看了5.8的pivot模型源碼.
最終發(fā)現(xiàn)是5.8的在中間表Pivot Class默認將incrementing設置成了false,所以數據被成功插入,但是沒有設置插入后的主鍵ID,造成剩余服務崩潰,沒能正常運行...
修復方案
在每個Pivot Class中重新覆蓋掉incrementing屬性值為true即可.
class UserRole extends Pivot { public $incrementing = true; protected $fillable = [ 'user_id', 'role_id', ]; }
修復后:
laravel5.8: dd($pivot->id); //10003
以上是“l(fā)aravel中Pivot模型ID的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
分享標題:laravel中Pivot模型ID的示例分析-創(chuàng)新互聯(lián)
文章URL:http://bm7419.com/article8/gidop.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供品牌網站建設、外貿建站、商城網站、小程序開發(fā)、靜態(tài)網站、企業(yè)網站制作
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)