Mysql两表 join 查询方式

AffettoIris 2023-1-29 2,878 1/29

原文

一、SQL基本语法格式

SELECT DISTINCT
    < select_list > 
FROM
    < left_table > < join_type >
JOIN < right_table > ON <join_condition>
WHERE
    < where_condition > 
GROUP BY
    < group_by_list > 
HAVING
    < having_condition > 
ORDER BY
    < order_by_condition > 
LIMIT < limit_number >

二、3种join方式

1. left join(左连接)

A left join B 得到A表的所有字段,如果没有匹配到连接条件则用null填充

select A.*,B.* from A left join B on A.id = B.id;

Mysql两表 join 查询方式

2. right join(右连接)

A right join B 得到B表所有的字段

select A.*,B.* from A right join B on A.id=B.id;

Mysql两表 join 查询方式

3. inner join(内连接)

A inner join B得到(A和B的交集)

select A.*,B.* from A inner join B on A.id=B.id;

Mysql两表 join 查询方式

4. 在理解上面的三种join下,查询(A - A∩B)

select A.*,B.* from A left join B on A.id=B.id where B.id is null;

Mysql两表 join 查询方式

5. 查询 ( B - A∩B )

select A.*,B.* from A right join B on A.id=B.id where A.id is null;

Mysql两表 join 查询方式

6. 查询(A∪B - A∩B)

利用union去重将上面的第四、第五种两条sql中间用union连接即可完成;即先完成一小部分的,然后将两个拼起来的思想。

select A.*,B.* from A left join B on A.id=B.id where B.id is null



union



select A.*,B.* from A right join B on A.id=B.id where A.id is null;

Mysql两表 join 查询方式

7. 查询 AUB

MySQL中求并集可以使用union关键字进行处理(自动去重)

select A.*,B.* from A left join B on A.id=B.id



UNION



select A.*,B.* from A right join B on A.id=B.id;

Mysql两表 join 查询方式

附:经测试,如果你想查询两表的多个字段
select A.column1,A.column2,B.column1, B.column2 from A left join B on A.id = B.id; 是最好的,除了下面的应该没有其他写法了。
如果column1是A特有的,B中没有重名的列,你可以如下(为了代码的可维护性和可拓展,建议不要偷懒)
select column1,A.column2,B.column1, B.column2 from A left join B on A.id = B.id;
但如果B中有重名的列,报错:Column 'column1' in field list is ambiguous
- THE END -

AffettoIris

10月16日15:53

最后修改:2023年10月16日
0

非特殊说明,本博所有文章均为博主原创。

共有 0 条评论