mysql 只写join_MySQL中join的7种方法

join查询的7中方法

手写顺序:

SELECT DISTINCT

FROM

JOIN ON

WHERE

GROUP BY

HAVING

ORDER BY

LIMIT

MySQL执行顺序

FROM

ON

JOIN

WHERE

GROUP BY

HAVING

DISTINCT

ORDER BY

LIMIT

f66affaa88fd119677e767d18aaa3b5a.png

join连接方式:

内连接:

2719a0d3bc1b181285c3335979ea77c3.png

SELECT FROM TableA A INNER JOIN TableB B ON A.Key = B.Key

左连接:

2f5797281126d6e745becea8f84d85d9.png

SELECT FROM TableA A LEFT JOIN TableB B ON A.Key = B.Key

右连接:

e50bd86d5d95f7505d715bd9fe11ac20.png

SELECT FROM TableA A RIGHT JOIN TableB B ON A.Key = B.Key

只有A

57b1a61026f12a168286bb1eca589572.png

SELECT FROM TableA A LEFT JOIN TableB B ON A.Key = B.Key WHERE B.Key IS NULL

只有B

f46a72ecd3fb8d97f912333523157328.png

SELECT FROM TableA A RIGHT JOIN TableB B ON A.Key = B.Key WHERE A.Key IS NULL

全连接

6ab5300335a69e3db6a559e4d8cdb1cd.png

# MySQL没有FULL OUTER语法。

SELECT FROM TableA A LEFT JOIN TableB B ON A.Key = B.Key

union

SELECT FROM TableA A RIGHT JOIN TableB B ON A.Key = B.Key;

A,B各自独有:

defab05a006e8d1dcdfb3707419175c6.png

# MySQL没有FULL OUTER语法。

SELECT FROM TableA A LEFT JOIN TableB B ON A.Key = B.Key WHERE B.Key IS NULL

union

SELECT FROM TableA A RIGHT JOIN TableB B ON A.Key = B.Key WHERE A.Key IS NULL;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值