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中文網其他相關文章!