假設我們有 2 張桌子
TABLEA TABLEB
1 1 01/03/2022
2 2 01/01/2022
3
此 SQL 陳述句:
select id
from tableA
left join tableB on tableA.id = tableB.id
顯示:
1 1 01/03/2022
2 2 01/01/2022
3 NUll
不幸的是,當我在右表上添加限制時,行為就不一樣了。
select id
from tableA
left join tableB on tableA.id = tableB.id
where tableB.date > '01/01/2022'
我想要這樣的東西:
1 1 01/03/2022
2 NULL
3 NULL
但我明白了:
1 1 01/03/2022
就這樣。我沒想到這種行為。有人可以告訴查詢應該是什么嗎?
uj5u.com熱心網友回復:
CREATE TABLE #TABLEA
(
ID tinyint
);
CREATE TABLE #TABLEB
(
ID tinyint
,Date date
);
INSERT INTO #TABLEA
VALUES(1),(2),(3)
INSERT INTO #TABLEB
VALUES(1,'2022-03-01'),(2,'2022-01-01'),(3,NULL)
SELECT
*
FROM
#TABLEA t1
LEFT JOIN #TABLEB t2 ON t2.ID= t1.ID
AND t2.Date > '2022-01-01'
DROP TABLE
#TABLEA
,#TABLEB;
當您添加 WHERE 子句時,您實際上將 LEFT JOIN 更改為 INNER JOIN。將條件放在 JOIN 謂詞中可以保持 LEFT JOIN 符合預期。
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/474666.html
上一篇:使用SQL查詢從多個表中洗掉記錄
