获取女生表中,没有男朋友的女生
不用连接
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))