数据表的连接

以如下两张数据表为例子来分析内连接,左外连接,右外连接,全外连接以及交叉连接的区别:

table_1 

namesex
Johnman
Lily woman
NULLNULL

table_2
name2age
Lily18
Mike23
NULLNULL

在机子上mysql上创建的两张表:


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

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



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



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



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

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



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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值