首頁 >資料庫 >mysql教程 >SQL JOIN 中的 WHERE 與 ON:何時應該使用每個子句?

SQL JOIN 中的 WHERE 與 ON:何時應該使用每個子句?

DDD
DDD原創
2025-01-05 13:10:44273瀏覽

WHERE vs. ON in SQL JOINs: When Should I Use Each Clause?

探索JOIN 中WHERE 子句和ON 條件的區別

SQL 實踐者在執行JOIN 操作時經常交替使用WHERE 子句和ON 條件。雖然兩種方法可以傳回相同的結果,但需要考慮一些細微差別。

在提供的範例中,提供了兩個SQL 查詢:

SELECT *
FROM Foo AS f
INNER JOIN Bar AS b ON b.BarId = f.BarId
WHERE b.IsApproved = 1;

SELECT *
FROM Foo AS f
INNER JOIN Bar AS b ON (b.IsApproved = 1) AND (b.BarId = f.BarId);

兩個查詢傳回相同的行集,但它們的執行有一個關鍵的區別。當過濾器放置在 WHERE 子句中時,它會在 JOIN 操作之後套用。這意味著 JOIN 將從兩個表中檢索所有匹配的行,即使是 b.IsApproved 為 false 的行。然後,WHERE 子句會過濾掉不符合條件 b.IsApproved = 1 的行。

相反,當過濾器置於 ON 條件時,會在 JOIN 之前評估條件。因此,只有 b.BarId 和 b.IsApproved 都滿足指定條件的行才會包含在 JOIN 中。

外部聯結和過濾器放置

但是,在處理外連接時,這種差異變得尤為重要。考慮以下左外連接查詢:

SELECT *
FROM Foo AS f
LEFT OUTER JOIN Bar AS b ON (b.IsApproved = 1) AND (b.BarId = f.BarId);

在這種情況下,ON 條件下的過濾器將排除b.IsApproved 為false 的行或給定f 沒有匹配的b.BarId 的行. BarId。此行為與將過濾器放在WHERE 子句中不同:

SELECT *
FROM Foo AS f
LEFT OUTER JOIN Bar AS b ON (b.BarId = f.BarId)
WHERE b.IsApproved = 1;

在第二個查詢中,b.IsApproved 為false 或涉及失敗聯接的行仍將返回,但b.IsApproved 將返回設定為NULL。

因此,在使用外部連接時,必須仔細考慮過濾器的放置。 ON 條件過濾連接之前的行,而 WHERE 子句過濾連接之後的結果。

為了完成討論,如果您希望在左外連接中使用OPTIONAL 過濾器,以下查詢演示了正確的位置:

SELECT *
FROM Foo AS f
LEFT OUTER JOIN Bar AS b ON (b.BarId = f.BarId)
WHERE b.IsApproved IS NULL OR b.IsApproved = 1;

此查詢返回連接成功且b.IsApproved 滿足條件的行,以及連接失敗的行(導致NULL 值)對於b.IsApproved)。

以上是SQL JOIN 中的 WHERE 與 ON:何時應該使用每個子句?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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