如何使用空条目从 SQL 中的 2 个表中获取数据
how to fetch data from 2 tables in SQL with null Entries
我的表格看起来像这样
-- t1
id col_1
1 Tim
2 Marta
-- t2
id col_2
1 Tim
3 Katarina
我想要这样的结果吗?
--Result
id col_1 col_2
1 Tim Tim
2 Marta *Null*
3 *Null* Katarina
如果有人知道如何使用 SQL 执行此操作,请告诉我?
你想要 full join
,MySQL 不支持一种方法是获取所有 ID 并使用 left join
:
select *
from (select id from t1
union -- on purpose to remove duplicates
select id from t2
) i left join
t1
using (id) left join
t2
using (id);
试试这个
select t1.id, t1.col_1, t2.col_2
FROM t1 LEFT OUTER JOIN t2 ON (t1.id=t2.id)
UNION
SELECT t2.id, t1.col_1, t2.col_2
FROM t2 LEFT OUTER JOIN t1 ON (t2.id = t1.id)
MySQL没有FULL OUTER JOIN,所以需要模拟一下,但是注意是slw
CREATE tABLE t1(id int, col_1 varchar(50))
INSERT INTO t1 VALUES (1,'Tim'),(2,'Martqa')
CREATE tABLE t2(id int, col_2 varchar(50))
INSERT INTO t2 VALUES (1,'Tim'),(3,'Katarina')
SeLECT t1.id, t1.col_1,t2.col_2
FROM t1 LEFT JOIN t2 USING(id)
UNION
SeLECT t2.id, t1.col_1,t2.col_2
FROM t1 RIGHT JOIN t2 USING(id)
id | col_1 | col_2
-: | :----- | :-------
1 | Tim | Tim
2 | Martqa | null
3 | null | Katarina
SeLECT t1.id, t1.col_1,t2.col_2
FROM t1 LEFT JOIN t2 USING(id)
WHERE t1.id > 1
UNION
SeLECT t2.id, t1.col_1,t2.col_2
FROM t1 RIGHT JOIN t2 USING(id)
WHERE t2.id > 1
id | col_1 | col_2
-: | :----- | :-------
2 | Martqa | null
3 | null | Katarina
SELECT * FROM
(SeLECT t1.id, t1.col_1,t2.col_2
FROM t1 LEFT JOIN t2 ON t1.id = t2.id
UNION
SeLECT t2.id, t1.col_1,t2.col_2
FROM t1 RIGHT JOIN t2 ON t1.id = t2.id) t1
WHERE id > 1
id | col_1 | col_2
-: | :----- | :-------
2 | Martqa | null
3 | null | Katarina
db<>fiddle here
我的表格看起来像这样
-- t1
id col_1
1 Tim
2 Marta
-- t2
id col_2
1 Tim
3 Katarina
我想要这样的结果吗?
--Result
id col_1 col_2
1 Tim Tim
2 Marta *Null*
3 *Null* Katarina
如果有人知道如何使用 SQL 执行此操作,请告诉我?
你想要 full join
,MySQL 不支持一种方法是获取所有 ID 并使用 left join
:
select *
from (select id from t1
union -- on purpose to remove duplicates
select id from t2
) i left join
t1
using (id) left join
t2
using (id);
试试这个
select t1.id, t1.col_1, t2.col_2
FROM t1 LEFT OUTER JOIN t2 ON (t1.id=t2.id)
UNION
SELECT t2.id, t1.col_1, t2.col_2
FROM t2 LEFT OUTER JOIN t1 ON (t2.id = t1.id)
MySQL没有FULL OUTER JOIN,所以需要模拟一下,但是注意是slw
CREATE tABLE t1(id int, col_1 varchar(50))
INSERT INTO t1 VALUES (1,'Tim'),(2,'Martqa')
CREATE tABLE t2(id int, col_2 varchar(50))
INSERT INTO t2 VALUES (1,'Tim'),(3,'Katarina')
SeLECT t1.id, t1.col_1,t2.col_2 FROM t1 LEFT JOIN t2 USING(id) UNION SeLECT t2.id, t1.col_1,t2.col_2 FROM t1 RIGHT JOIN t2 USING(id)
id | col_1 | col_2 -: | :----- | :------- 1 | Tim | Tim 2 | Martqa | null 3 | null | Katarina
SeLECT t1.id, t1.col_1,t2.col_2 FROM t1 LEFT JOIN t2 USING(id) WHERE t1.id > 1 UNION SeLECT t2.id, t1.col_1,t2.col_2 FROM t1 RIGHT JOIN t2 USING(id) WHERE t2.id > 1
id | col_1 | col_2 -: | :----- | :------- 2 | Martqa | null 3 | null | Katarina
SELECT * FROM (SeLECT t1.id, t1.col_1,t2.col_2 FROM t1 LEFT JOIN t2 ON t1.id = t2.id UNION SeLECT t2.id, t1.col_1,t2.col_2 FROM t1 RIGHT JOIN t2 ON t1.id = t2.id) t1 WHERE id > 1
id | col_1 | col_2 -: | :----- | :------- 2 | Martqa | null 3 | null | Katarina
db<>fiddle here