如何使用空条目从 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