久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP中Laravel 關聯查詢返回錯誤id的解決方法

這篇文章主要介紹了Laravel 關聯查詢返回錯誤id的解決方法,非常不錯,具有參考借鑒價值,需要的朋友參考下吧

在 Laravel Eloquent 中使用 join 關聯查詢,如果兩張表有名稱相同的字段,如 id,那么它的值會默認被后來的同名字段重寫,返回不是期望的結果。例如以下關聯查詢:

PHP

$priority = Priority::rightJoin('touch', 'priorities.touch_id', '=', 'touch.id')
 ->where('priorities.type', 1)
 ->orderBy('priorities.total_score', 'desc')
 ->orderBy('touch.created_at', 'desc')
 ->get();
$priority = Priority::rightJoin('touch', 'priorities.touch_id', '=', 'touch.id')
 ->where('priorities.type', 1)
 ->orderBy('priorities.total_score', 'desc')
 ->orderBy('touch.created_at', 'desc')
 ->get();

priorities 和 touch 這兩張表都有 id 字段,如果這樣構造查詢的話,返回的查詢結果如圖:

Laravel 關聯查詢返回錯誤的 id

這里 id 的值不是 priorities 表的 id 字段,而是 touch 表的 id 字段,如果打印出執行的 sql 語句:

select * from `priorities` 
right join `touch` 
on `priorities`.`touch_id` = `touch`.`id` 
where `priorities`.`type` = '1' 
order by `priorities`.`total_score` desc, `touch`.`created_at` desc
select * from `priorities` 
right join `touch` 
on `priorities`.`touch_id` = `touch`.`id` 
where `priorities`.`type` = '1' 
order by `priorities`.`total_score` desc, `touch`.`created_at` desc

查詢結果如圖:

使用 sql 查詢的結果實際上是對的,另外一張表重名的 id 字段被默認命名為 id1,但是 Laravel 返回的 id 的值卻不是圖中的 id 字段,而是被重名的另外一張表的字段重寫了。

解決辦法是加一個 select 方法指定字段,正確的構造查詢語句的代碼:

PHP

$priority = Priority::select(['priorities.*', 'touch.name', 'touch.add_user'])
 ->rightJoin('touch', 'priorities.touch_id', '=', 'touch.id')
 ->where('priorities.type', 1)
 ->orderBy('priorities.total_score', 'desc')
 ->orderBy('touch.created_at', 'desc')
 ->get();
$priority = Priority::select(['priorities.*', 'touch.name', 'touch.add_user'])
 ->rightJoin('touch', 'priorities.touch_id', '=', 'touch.id')
 ->where('priorities.type', 1)
 ->orderBy('priorities.total_score', 'desc')
 ->orderBy('touch.created_at', 'desc')
 ->get();

這樣就解決了問題,那么以后就要注意了,Laravel 兩張表 join 的時候返回的字段最好要指定。

這算不算是 Laravel 的一個 bug 呢?如果一個字段的值被同名的字段值重寫了,這種情況要不要報一個錯誤出來,而不能默認繼續執行下去。

github 上有人也提出了同樣的問題,作者也提供了解決辦法,但并沒其他更好的方案。

Laravel 版本:5.3

鏈接:https://github.com/laravel/framework/issues/4962

以上所述是小編給大家介紹的Laravel 關聯查詢返回錯誤的 id的解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!

【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

下面小編就為大家分享一篇laravel ORM 只開啟created_at的幾種方法總結,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要給大家介紹了如何通過源碼解析Laravel的依賴注入的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著
這篇文章主要給大家介紹了關于Laravel中unique和exists驗證規則的優化的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面
最近在使用laravel5.5,利用其實現了一個功能,下面分享給大家,這篇文章主要給大家介紹了關于Laravel 5.5基于內置的Auth模塊如何實現前后臺登陸的相關資料,文中通過示例代碼介紹的非
laravel 的隊列服務對各種不同的后臺隊列服務提供了統一的 API,下面這篇文章通過源碼分析給大家介紹了關于 Laravel 重復執行同一個隊列任務的原因,文中通過示例代碼介紹的非常詳細
這篇文章主要給大家介紹了關于 Laravel Redis 多個進程同時取隊列問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或工作具有一定的參考學習價值,需要的朋友下面來
主站蜘蛛池模板: 中文天堂网 | 四虎在线观看 | 蜜桃免费一区二区三区 | 久久的色| 日韩一区在线观看视频 | 国产成人99久久亚洲综合精品 | 高清欧美性猛交xxxx黑人猛交 | 国产一区二 | 色在线免费视频 | 国产综合久久久 | 国产高清性xxxxxxxx | 国产精品一区一区 | 国产91观看 | 精品无码久久久久久久动漫 | 黄色在线网站 | 中文字幕在线视频免费视频 | 久久精品久久精品久久精品 | 99热视| 正在播放国产精品 | 久久久精品一区二区 | 九久久| 91大神xh98xh系列全部 | 日韩成人一区 | 一区二区精品 | 欧美精品1区2区3区 免费黄篇 | 国产日韩欧美一区 | 亚洲精品一区二区三区中文字幕 | 久久精品久久久 | 丁香婷婷综合激情五月色 | 国产精品美女久久久久久久网站 | 亚洲成人免费av | 中文字幕一区二区三区在线观看 | 日韩国产一区二区三区 | 国产精品1区2区3区 欧美 中文字幕 | 超碰地址| 国产日韩精品在线 | 亚洲a视频 | 国产精品99久久久久久久久 | 欧美一区二区三区久久精品视 | 亚洲精品福利在线 | 91天堂网|