关于SQL的各种Join你知道多少?

SQL中的 join,无外乎 inner join、outer join 以及 cross join,而 inner join 其实就是我们熟知的 join,outer join 其实就是 left outer join、right outer join 和 full outer join。

inner join

通过连接键列中的值进行匹配,仅相同键值的记录在结果集中,两个表中没有匹配的记录不包括在结果集中。

LEFT OUTER JOIN

LEFT OUTER JOIN (或 LEFT JOIN)返回左表中的所有内容,右表中匹配的行以及右表中没有匹配的记录用 NULL 填充。

RIGHT OUTER JOIN

RightOUTERJOIN (或 RightJOIN)返回右表中的所有内容,匹配的行在左表中,坐标中没有匹配的记录填充为 NULL。

FULL OUTER JOIN

在 FULL OUTER JOIN(或 FULL JOIN)中,记录由连接键列中的值进行匹配,相同键值的记录将被匹配,而两个表中不匹配的记录将被填充为 NULL。

CROSS JOIN

CROSS JOIN: 返回表1的每一行和表2的每一行的笛卡儿积,所以如果表1包含6行,表2包含5行,结果将产生30个结果(6 * 5 = 30)

总结

扩展

left anti join 和 right anti join

相关推荐
追逐时光者4 小时前
一款开源、现代化的 WinForm UI 控件库
后端·.net
花月C5 小时前
个性化推荐:基于用户的协同过滤算法
开发语言·后端·算法·近邻算法
cci6 小时前
还在用conda?,试试uv,提高包的安装速度
后端
cci6 小时前
设备每次插入Linux识别的串口不一样?试试udev!
后端
9ilk7 小时前
【C++】--- C++11
开发语言·c++·笔记·后端
码事漫谈9 小时前
VSCode CMake Tools 功能解析、流程与最佳实践介绍
后端
火云牌神9 小时前
本地大模型编程实战(38)实现一个通用的大模型客户端
人工智能·后端
码事漫谈9 小时前
从C++/MFC到CEF与TypeScript的桌面架构演进
后端
冰块的旅行10 小时前
magic-api使用
后端
用户895356032822010 小时前
Goroutine + Channel 高效在哪?一文吃透 Go 并发底层 G-M-P 调度与实现
后端·go