失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 笛卡儿积 左连接 右连接

笛卡儿积 左连接 右连接

时间:2022-01-01 13:51:14

相关推荐

笛卡儿积 左连接 右连接

要理解啥是左连接、右连接,就要先理解一些问题。

啥是笛卡儿积

我们看下面这两张表T1T2

SELECT * FROM T1+-------------+-------------+| A | B |+-------------+-------------+| A1| B1|| A2| B2|+-------------+-------------+SELECT * FROM T2+-------------+-------------+| B | C |+-------------+-------------+| B2| C2|| B3| C3|+-------------+-------------+

T1T2做笛卡尔积

SELECT * FROM T1 CROSS JOIN T2+-------------+-------------+-------------+-------------+| A | B | B | C |+-------------+-------------+-------------+-------------+| A1| B1| B2| C2|| A2| B2| B2| C2|| A1| B1| B3| C3|| A2| B2| B3| C3|+-------------+-------------+-------------+-------------+

可以看到,是把T1中的每一个元组(行)与T2中的每一个元组都进行了一次组合。

啥是连接

连接一般叫做θ-连接(theta-Join),通俗理解是从笛卡儿积中选择出符合条件的元组。

例如我们以T1.BT2.B相等作为条件对两个表进行连接

SELECT * FROM T1 JOIN T2 ON T1.B=T2.B+-------------+-------------+-------------+-------------+| A | B | B | C |+-------------+-------------+-------------+-------------+| A2| B2| B2| C2|+-------------+-------------+-------------+-------------+

可以看到,只有当T1.B的值为B2时,才能在T2表中找到一条相匹配的记录。

啥是左连接

LEFT JOIN - 列出左表中所有的元组,即使右表中没有可以与之相匹配的元组。话不多说,直接看结果就可以理解了。

SELECT * FROM T1 LEFT JOIN T2 ON T1.B=T2.B+-------------+-------------+-------------+-------------+| A | B | B | C |+-------------+-------------+-------------+-------------+| A2| B2| B2| C2|| A1| B1| null | null |+-------------+-------------+-------------+-------------+

即使(A1,B1)在T2表中没有可以进行匹配的元组,但还是会在结果中输出。

啥是右连接

同左连接定义,总是列出右表中的所有元组,即使在左表中没有符合条件的元组。

SELECT * FROM T1 RIGHT JOIN T2 ON T1.B=T2.B+-------------+-------------+-------------+-------------+| A | B | B | C |+-------------+-------------+-------------+-------------+| A2| B2| B2| C2|| | | B3| C3|+-------------+-------------+-------------+-------------+

如果觉得《笛卡儿积 左连接 右连接》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。