以如下两张数据表为例子来分析内连接,左外连接,右外连接,全外连接以及交叉连接的区别:
table_1
name | sex |
John | man |
Lily | woman |
NULL | NULL |
table_2
name2 | age |
Lily | 18 |
Mike | 23 |
NULL | NULL |
在机子上mysql上创建的两张表:
1 内连接,即自然连接。只连接匹配的行。
只有两张表的数据相匹配的记录才被提取出来。
2 左外连接:包含左边表的全部以及右表中匹配的行。(不管右边的表是否存在与他们匹配的行,没有用NULL表示)
3 右外连接:包含右边表的全部以及左表中匹配的行。(不管左边的表是否存在与他们匹配的行,没有用NULL表示)
4全外连接:包含左右两个表全部的行(不管另外的表中是否存在与它们匹配的行)
由于mysql不直接支持全外连接,所以利用左连接和有连接,再加上UNION语句实现全外连接
5交叉连接:即生成笛卡尔积。不适用任何匹配条件,直接将左边的每一行和右边的表的所有行一一匹配。