搜索
首页数据库SQL一起聊聊SQL的表连接

本篇文章给大家带来了关于SQL的相关知识,其中主要介绍了关于表连接的相关内容,SQL Server中支持多种连接,包括内连接、左连接、右连接、交叉连接和全外连接,下面一起来看一下,希望对大家有帮助。

一起聊聊SQL的表连接

推荐学习:《SQL教程

SQL的表连接

在关系数据库中,数据分布在多个逻辑表。想要获得完整有意义的数据集,则需要使用连接来查询这些表中的数据。SQL Server中支持多种连接,包括内连接、左连接、右连接、交叉连接和全外连接。

一、内连接

内部连接子句用于查询来自两个或多个相关表的数据。INNER JOIN 子句的语法:

SELECT p.product_name, p.list_price ,c.category_nameFROM production.products p 
INNER JOIN production.categories c ON c.category_id = p.category_id

注意:要查询的字段,必须要在字段的前面加上表名或者表的别名,如:p.product_name
其中FROM后面的是主表,然后 INNER JOIN 后面的表是要连接的表。主表和连接表进行比较,查 找满足的条件的所有行。连接谓词的计算结果为true是,则将主表和连接表进行合并成新的结果 集,如下图所示:

一起聊聊SQL的表连接

内连接的多个表连接,如下所示:

SELECT p.product_name, p.list_price ,c.category_name, b.brand_nameFROM production.products p 
INNER JOIN production.categories c ON c.category_id = p.category_id 
INNER JOIN production.brands b ON b.brand_id = p.brand_id

二、左连接

在左连接中使用 LEFT JOIN 子句用于查询来自多个表的数据,它返回是左表中的所有行和右表中匹配行。若是右表中找不到匹配行,则使用NULL代替显示,如图所示:

一起聊聊SQL的表连接

使用 LEFT JOIN 语句进行连接:如下所示:

SELECT p.product_name, p.list_price ,c.category_nameFROM production.products p 
LEFT JOIN production.categories c ON c.category_id = p.category_id

在上面的语法中 FROM 后面的表是左表(production.products),而 LEFT JOIN 后面紧跟的右 表(production.categories)。

三、右连接

在右连接中使用RIGHT JOIN子句来进行两个表或多个表进行查询。右查询刚好与左查询的是相反 的,返回右表的所有行和左表的匹配行,若左表找不到匹配行,则返回NULL代替显示,如图所示:

一起聊聊SQL的表连接

使用 RIGHT JOIN 语句进行连接:如下所示:

SELECT p.product_name, p.list_price ,c.category_nameFROM production.products p 
RIGHT JOIN production.categories c ON c.category_id = p.category_id

在上面的语法中 FROM 后面的表是左表(production.products),而 RIGHT JOIN 后面紧跟的右 表(production.categories)。

四、交叉连接

CROSS JOIN 连接两个或多个不相关的表。 以下是两个表的CROSS JOIN 的语法,两种写法:

SELECT T1.select_list 
FROM T1 CROSS JOIN T2;

或者

SELECT T1.select_list 
FROM T1, T2;

CROSS JOIN 将第一个表(T1)中的每一行与第二个表(T2)中的每一行连接起来。 换句话说,交叉连 接返回两个表中行的笛卡尔积。与INNER JOIN或LEFT JOIN不同,交叉连接不会在连接的表之间 建立关系。
假设 T1 表包含三行: 1 , 2 和 3 , T2 表包含三行: A , B 和 C 。 CROSS JOIN 从第一个 表(T1)获取一行,然后为第二个表(T2)中的每一行创建一个新行。 然后它对 第一个 表(T1)中的 下一行执行相同操作,依此类推。在此图中, CROSS JOIN 总共创建了 9 行。

五、自连接

自联接用于将表连接到自身(同一个表)。 它对于查询分层数据或比较同一个表中的行很有用。
自联接使用内连接或左连接子句。 由于使用自联接的查询引用同一个表,因此表别名用于为查询 中的表分配不同的名称。
注意:如果在不使用表别名的情况下在查询中多次引用同一个表,则会出现错误。
示例:

SELECT t1.select_list 
FROM T1 t1INNER JOIN T1 t2 ON t1.category_id = t2.category_id

在 INNER JOIN 这里可以使用其他的子句,比如:LEFT JOIN ,RIGHT JOIN

六、全外连接

FULL OUTER JOIN当左表或右表中存在匹配项时,该命令将返回所有行。如图所示:

一起聊聊SQL的表连接

使用 FULL OUTER JOIN 查询 pm.projects 表和 pm.member 表中的数据:

SELECT m.name member, p.title project 
FROM pm.members m 
FULL OUTER JOIN pm.projects p ON p.id = m.project_id;

pm.projects 表数据:
一起聊聊SQL的表连接

pm.member 表数据:

一起聊聊SQL的表连接

查询结果:
一起聊聊SQL的表连接

推荐学习:《SQL教程

以上是一起聊聊SQL的表连接的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:CSDN。如有侵权,请联系admin@php.cn删除
SQL与MySQL:澄清两者之间的关系SQL与MySQL:澄清两者之间的关系Apr 24, 2025 am 12:02 AM

SQL是一种用于管理关系数据库的标准语言,而MySQL是一个使用SQL的数据库管理系统。SQL定义了与数据库交互的方式,包括CRUD操作,而MySQL实现了SQL标准并提供了额外的功能,如存储过程和触发器。

SQL的重要性:数字时代的数据管理SQL的重要性:数字时代的数据管理Apr 23, 2025 am 12:01 AM

SQL在数据管理中的作用是通过查询、插入、更新和删除操作来高效处理和分析数据。1.SQL是一种声明式语言,允许用户以结构化方式与数据库对话。2.使用示例包括基本的SELECT查询和高级的JOIN操作。3.常见错误如忘记WHERE子句或误用JOIN,可通过EXPLAIN命令调试。4.性能优化涉及使用索引和遵循最佳实践如代码可读性和可维护性。

SQL入门:基本概念和技能SQL入门:基本概念和技能Apr 22, 2025 am 12:01 AM

SQL是一种用于管理和操作关系数据库的语言。1.创建表:使用CREATETABLE语句,如CREATETABLEusers(idINTPRIMARYKEY,nameVARCHAR(100),emailVARCHAR(100));2.插入、更新、删除数据:使用INSERTINTO、UPDATE、DELETE语句,如INSERTINTOusers(id,name,email)VALUES(1,'JohnDoe','john@example.com');3.查询数据:使用SELECT语句,如SELEC

SQL:语言,MySQL:数据库管理系统SQL:语言,MySQL:数据库管理系统Apr 21, 2025 am 12:05 AM

SQL和MySQL的关系是:SQL是用于管理和操作数据库的语言,而MySQL是支持SQL的数据库管理系统。1.SQL允许进行数据的CRUD操作和高级查询。2.MySQL提供索引、事务和锁机制来提升性能和安全性。3.优化MySQL性能需关注查询优化、数据库设计和监控维护。

SQL的作用:管理和操纵数据SQL的作用:管理和操纵数据Apr 20, 2025 am 12:02 AM

SQL用于数据库管理和数据操作,核心功能包括CRUD操作、复杂查询和优化策略。1)CRUD操作:使用INSERTINTO创建数据,SELECT读取数据,UPDATE更新数据,DELETE删除数据。2)复杂查询:通过GROUPBY和HAVING子句处理复杂数据。3)优化策略:使用索引、避免全表扫描、优化JOIN操作和分页查询来提升性能。

SQL:对数据管理的初学者友好方法?SQL:对数据管理的初学者友好方法?Apr 19, 2025 am 12:12 AM

SQL适合初学者,因为它语法简单,功能强大,广泛应用于数据库系统。1.SQL用于管理关系数据库,通过表格组织数据。2.基本操作包括创建、插入、查询、更新和删除数据。3.高级用法如JOIN、子查询和窗口函数增强数据分析能力。4.常见错误包括语法、逻辑和性能问题,可通过检查和优化解决。5.性能优化建议包括使用索引、避免SELECT*、使用EXPLAIN分析查询、规范化数据库和提高代码可读性。

SQL在行动中:现实世界中的示例和用例SQL在行动中:现实世界中的示例和用例Apr 18, 2025 am 12:13 AM

SQL在实际应用中主要用于数据查询与分析、数据整合与报告、数据清洗与预处理、高级用法与优化以及处理复杂查询和避免常见错误。1)数据查询与分析可用于找出销售量最高的产品;2)数据整合与报告通过JOIN操作生成客户购买报告;3)数据清洗与预处理可删除异常年龄记录;4)高级用法与优化包括使用窗口函数和创建索引;5)处理复杂查询可使用CTE和JOIN,避免常见错误如SQL注入。

SQL和MySQL:了解核心差异SQL和MySQL:了解核心差异Apr 17, 2025 am 12:03 AM

SQL是一种用于管理关系数据库的标准语言,而MySQL是一个具体的数据库管理系统。SQL提供统一语法,适用于多种数据库;MySQL轻量、开源,性能稳定但在大数据处理上有瓶颈。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

螳螂BT

螳螂BT

Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器