您的位置:首页 > 其它

数据表的连接

2015-08-03 17:01 211 查看
以如下两张数据表为例子来分析内连接,左外连接,右外连接,全外连接以及交叉连接的区别:

table_1

namesex
Johnman
Lily woman
NULLNULL
table_2

name2age
Lily18
Mike23
NULLNULL
在机子上mysql上创建的两张表:



1 内连接,即自然连接。只连接匹配的行。

只有两张表的数据相匹配的记录才被提取出来。



2 左外连接:包含左边表的全部以及右表中匹配的行。(不管右边的表是否存在与他们匹配的行,没有用NULL表示)



3 右外连接:包含右边表的全部以及左表中匹配的行。(不管左边的表是否存在与他们匹配的行,没有用NULL表示)



4全外连接:包含左右两个表全部的行(不管另外的表中是否存在与它们匹配的行)

由于mysql不直接支持全外连接,所以利用左连接和有连接,再加上UNION语句实现全外连接



5交叉连接:即生成笛卡尔积。不适用任何匹配条件,直接将左边的每一行和右边的表的所有行一一匹配。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: