Laravel with和join一起用的時候需要注意

現(xiàn)象:Article::query()->with('user')->join('details','articles.id','=','details.article_id')->where('details.content','like','%test%')->get();

問題:這樣寫會導(dǎo)致model中article表的id被details表中的id覆蓋,with的時候user原本關(guān)聯(lián)的是article表的ID,此時確錯誤的關(guān)聯(lián)了details表中的ID,導(dǎo)致數(shù)據(jù)錯亂。

解決辦法:指定ID字段,或放棄join,改用子查詢
->select(['articles.id',....])

->whereIn(Detail::query()->where('content','like','%test%')->pluck('id'))

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • https://www.bilibili.com/video/av19538278?p=2https://blog...
    指向遠(yuǎn)方的燈塔閱讀 711評論 0 1
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,840評論 18 399
  • 1、ValueError: Incompatible indexer with Series 一般是datafra...
    Rainysong閱讀 15,033評論 0 8
  • MySQL 性能優(yōu)化 1. 靈魂拷問 MySQL的索引在執(zhí)行過程中是如何被使用的? MySQL的表數(shù)據(jù)和索引在底層...
    二俊_5254閱讀 355評論 0 0
  • ● 外鍵的刪除操作---on_delete參數(shù)指定 <1> models.CASCADE---級聯(lián)刪除外鍵表的字段...
    費(fèi)云帆閱讀 259評論 0 0

友情鏈接更多精彩內(nèi)容