久久久久久久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 多個進程同時取隊列問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或工作具有一定的參考學習價值,需要的朋友下面來
主站蜘蛛池模板: www国产成人免费观看视频,深夜成人网 | 亚洲电影第三页 | 日韩在线不卡 | 在线国产一区二区 | 狠狠av| av中文字幕在线 | 国产日韩视频 | 中文字幕国 | 精品亚洲一区二区 | 欧美一级免费看 | 一区二区三区视频在线观看 | www.国产一区| 成人在线视频免费看 | 性做久久久久久免费观看欧美 | 中文字幕免费在线 | 欧洲成人 | 日韩欧美三区 | 久久国产精品首页 | 欧美一区二区三区国产 | 日韩精品视频在线观看一区二区三区 | 国产精品揄拍一区二区 | 亚洲国产一区二区三区在线观看 | 精品久久香蕉国产线看观看亚洲 | 日韩欧美二区 | 九九久久免费视频 | a国产视频 | 97久久久久久 | 视频在线亚洲 | 欧美久久久网站 | 亚洲精品日本 | 色橹橹欧美在线观看视频高清 | 免费观看黄a一级视频 | 毛片电影| 欧美日韩精品在线免费观看 | 99精品在线 | 亚洲精品乱码久久久久久蜜桃91 | 成人午夜免费网站 | 高清国产午夜精品久久久久久 | 精品久久九九 | 免费看一区二区三区 | 精品国产一区二区三区久久影院 |