SQL外连接原理:用python代码表示运行过程

 

 获取女生表中,没有男朋友的女生

不用连接

SELECT `id`,`name`
FROM `beauty`
WHERE `boyfriend_id` NOT IN (SELECT b.`id` FROM `boys` b);

外连接

SELECT g.`id`,g.`name`
FROM `beauty` g
LEFT OUTER JOIN `boys` b
ON g.`boyfriend_id`=b.`id`
WHERE b.`id` IS NULL;

理解:

外连接其实是将一个主表的每条数据匹配到副表的所有数据上时,副表中多加了空值数据。

内连接原理:

先生成主表对副表的全部匹配的新表,然后依据连接条件对新表的数据进行筛选,得到最终结果。

内连接的伪代码:

joined_result = []
for a in A:
    for b in B:
        if a.key == b.key:
            joined_result.append((a,b))

 外连接原理:

同样是在生成新表的时候,会对副表新增加全空的数据,然后在对其筛选。但要注意Null值处理。

外连接伪代码:

result=[]
B.append(nan)
for a in A:
  for b in B:
    if a.key == b.key or b.key is nan: 
      result.append((a,b))

(拓展)全外连接伪代码:

result=[]
A.append(nan)
B.append(nan)
for a in A:
    for b in B:
        if a.key==b.key or isnan(a)^isnan(b):
            result.append((a,b))

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值