网站首页 > 基础教程 正文
JOIN连接的作用
JOIN 连接用于把来自两个或多个表的行结合起来,基于这些表之间的共同字段。
最常见的 JOIN 类型:INNER JOIN(简单的 JOIN)。 INNER JOIN 从多个表中返回满足 JOIN 条件的所有行。
示例数据库
让我们看看选自 "Orders" 表的数据:
然后,看看选自 "Customers" 表的数据:
请注意,"Orders" 表中的 "客户ID" 列指向 "Customers" 表中的客户ID。上面这两个表是通过 "客户ID" 列联系起来的。
JOIN实例
我们想知道每个订单ID都是哪些客户订购的,以及具体的订单时间。我们运行下面的 SQL 语句(包含 INNER JOIN):
SELECT o.订单ID, c.姓名, o.订单日期 FROM Orders o INNER JOIN Customers c ON o.客户ID=c.客户ID;
运行结果如下所示:
不同的 JOIN
在我们继续讲解实例之前,我们先列出您可以使用的不同的 SQL JOIN 类型:
- INNER JOIN:如果表中有至少一个匹配,则返回行
- LEFT JOIN:即使右表中没有匹配,也从左表返回所有的行
- RIGHT JOIN:即使左表中没有匹配,也从右表返回所有的行
- FULL JOIN:只要其中一个表中存在匹配,则返回行
INNER JOIN
内部链接INNER JOIN关键字选择两个表中具有匹配值的记录。
SQL INNER JOIN 语法
SELECT column_name(s)FROM table1INNER JOIN table2 ON table1.column_name = table2.column_name;
注释:INNER JOIN 与 JOIN 是相同的,上面的示例就是INNER JOIN
LEFT JOIN
SQL左链接LEFT JOIN关键字返回左表(表1)中的所有行,即使在右表(表2)中没有匹配。如果在正确的表中没有匹配,结果是NULL。
SQL LEFT JOIN 语法
SELECT column_name(s)FROM table1LEFT JOIN table2ON table1.column_name=table2.column_name;
或:
SELECT column_name(s)FROM table1LEFT OUTER JOIN table2ON table1.column_name=table2.column_name;
注释:在一些数据库中,LEFT JOIN称为LEFT OUTER JOIN。
LEFT JOIN示例
我们想看看客户Customers表中的所有用户是否都有下单,可以使用如下查询语言:
SELECT c.姓名,o.订单ID, o.订单日期 FROM Customers c LEFT JOIN Orders o ON o.客户ID=c.客户ID;
结果:
我们发现刘二,李四,赵七没有对应的订单ID和订单日期,是因为他们没有在订单表Orders中存在,没有匹配上他们的信息。但是由于是左连接,就把主表Customers的信息全部显示出来了,就是对应上图的table1。
RIGHT JOIN
SQL右链接 RIGHT JOIN 关键字返回右表(table2)的所有行,即使在左表(table1)上没有匹配。如果左表没有匹配,则结果为NULL。
SQL RIGHT JOIN 语法
SELECT column_name(s) FROM table1RIGHT JOIN table2 ON table1.column_name = table2.column_name;
注释:在一些数据库中,RIGHT JOIN 称为 RIGHT OUTER JOIN。
右连接与左连接的主表刚好相反,会将table2中的数据完全显示,如果table1中没有匹配上的就不显示。
FULL OUTER JOIN
当左(表1)或右(表2)表记录匹配时,FULL OUTER JOIN关键字将返回所有记录。
注意: FULL OUTER JOIN可能会返回非常大的结果集!
SQL FULL OUTER JOIN 语法
SELECT column_name(s) FROM table1FULL OUTER JOIN table2 ON table1.column_name = table2.column_name;
全连接就是将table1和table2的内容完全显示,不管有没有匹配上。
批注
JOIN在SQL中占有重要的地位,通过JOIN我们可以将有匹配关系的两张表或更多表进行关联,来获取我们想要的数据。关联的方式也比较灵活,常用的就是INNER JOIN,请务必掌握它。
猜你喜欢
- 2024-10-11 SQL语法——右连接 RIGHT JOIN 关键字
- 2024-10-11 数据筛选,如何像SQL一样使用Pandas完成JOIN连接、UNION合并查询
- 2024-10-11 SQL多个Join on 和Where间的执行顺序(nest loop join机制)
- 2024-10-11 SparkSQL大数据实战:揭开Join的神秘面纱
- 2024-10-11 SQL INNER JOIN 关键字 sql关键字union
- 2024-10-11 阿里规范不建议多表join,可这SQL要怎么写
- 2024-10-11 SQL RIGHT JOIN 关键字 sql语句 关键字
- 2024-10-11 Apache Flink 漫谈系列-JOIN 算子
- 2024-10-11 awk实现类sql的join操作 awvs结合sqlmap
- 2024-10-11 扩展FlinkSQL实现流与维表Join flinksql mysql维表
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)