首頁 > 資料庫 > mysql教程 > 為什麼我的 SQL 左連線只傳回一行而不是所有行?

為什麼我的 SQL 左連線只傳回一行而不是所有行?

Mary-Kate Olsen
發布: 2024-12-12 13:25:14
原創
219 人瀏覽過

Why Does My SQL Left Join Only Return One Row Instead of All Rows?

SQL 查詢未傳回所有具有左連接的行

此查詢旨在檢索jos_hp_properties 表(縮寫為pr)中的所有行使用jos_hp_properties2 表中的值(縮寫為pr7),其中名為field的欄位等於後一個表中的 23。但是,儘管 jos_hp_properties 表包含 27 行,但目前查詢僅傳回一行。

要解決此問題,應將WHERE 子句移至JOIN 語句,如下所示:

SELECT pr.*, pr7.value AS `room_price_high`
FROM `jos_hp_properties` pr
LEFT JOIN `jos_hp_properties2` pr7 
ON pr7.property=pr.id
AND 
pr7.field=23
登入後複製

使用此修改後的查詢,WHERE 子句不再限制連接之前的結果集。相反,即使 jos_hp_properties2 表中沒有欄位 23 的對應行(在這種情況下,傳回值將為 NULL),也會包含 jos_hp_properties 表中的行。這可確保傳回第一個表中的所有行以及第二個表中所需的資料(如果適用)。

以上是為什麼我的 SQL 左連線只傳回一行而不是所有行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板