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

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

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-12-12 13:25:14298瀏覽

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

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn