石小疯 发表于 2024-8-16 12:29:07

深入理解SQL中的INNER JOIN操纵

本文介绍了INNER JOIN的界说、使用场景、盘算方法及与其他JOIN的比较。INNER JOIN是关系数据库中常用的操纵,用于返回两个表中匹配的行,只有在毗连条件满足时才返回数据。本文详细解释了INNER JOIN的语法及其在一对多、多对多关系中的应用,通过示例展示其结果集行数的盘算方法。此外,文中还比较了INNER JOIN与LEFT JOIN、RIGHT JOIN、FULL JOIN和CROSS JOIN的异同,帮助读者理解不同类型的JOIN在实际查询中的应用场景。通过本文,读者可以或许掌握INNER JOIN的焦点概念和技能细节,提高SQL查询和数据处理的效率。
https://i-blog.csdnimg.cn/direct/bf3165b7a3e2439d93cb415db599f7ed.gif
一、InnerJoin 的界说和概念

在关系数据库中,JOIN操纵用于在两个或多个表之间基于某些条件进行毗连。INNER JOIN是最常见的JOIN类型之一,它仅返回两个表中匹配的行。了解INNER JOIN的界说和概念对于精确使用和优化SQL查询至关重要。
什么是INNER JOIN?

INNER JOIN用于返回两个表中基于指定条件匹配的行。换句话说,只有当毗连条件满足时,才会返回行。如果没有匹配的行,则不会在结果会合包罗这些行。
INNER JOIN的语法

标准SQL语法中,INNER JOIN的基本形式如下:
SELECT column_name(s)
FROM table1
INNER JOIN table2
ON table1.column_name = table2.column_name;
在这个语法中,table1和table2是要毗连的两个表,column_name(s)是要选择的列,ON子句指定了毗连条件。
INNER JOIN的使用场景

INNER JOIN广泛应用于各种场景,包罗:

[*]数据分析:从多个相关表中检索数据进行分析。
[*]数据聚合:结合多个表的数据进行汇总和统计。
[*]陈诉生成:生成基于多表数据的陈诉。
[*]数据验证:验证多个表之间的关系和数据一致性。
通过理解INNER JOIN的界说和概念,可以更有用地应用它来办理实际题目。
二、InnerJoin 关联结果的盘算方法

在实际应用中,INNER JOIN的结果集行数取决于毗连表之间的关系类型和匹配条件。为了准确盘算INNER JOIN的返回行数,我们必要深入了解以下几种环境:
一对多关系和多对多关系

在关系数据库中,一对多关系和多对多关系是两种常见的表关系类型。INNER JOIN在这两种关系中的行为有所不同,但可以通过理解它们的本质来统一盘算方法。
一对多关系

在一对多关系中,一个表中的每一行可以与另一个表中的多行相关联。INNER JOIN在一对多关系中的行为主要取决于子表中的匹配行数。
假设:


[*]表 A 具有 m 行。
[*]表 B 具有 n 行。
[*]表 A 中的每一行大概在表 B 中匹配零行、一行或多行。
如果表 A 中的每一行在表 B 中均匀匹配 k 行(k 可以是 0),那么INNER JOIN返回的总行数为 m * k。
多对多关系

在多对多关系中,一个表中的每一行可以与另一个表中的多行相关联,反之亦然。这种关系通常通过一个中心表(交叉表)来实现,该表包罗两个表的外键。
假设:


[*]表 A 具有 m 行。
[*]表 B 具有 n 行。
[*]中心表 C 具有 p 行,表现表 A 和表 B 之间的关系数量。
在这种环境下,INNER JOIN的结果集行数通常等于中心表 C 的行数,即 p 行。
Inner Join 关联结果的盘算方法

为了更好地理解INNER JOIN的盘算方法,下面我们将通过具体示例进行详细解说。
示例:一对多关系

假设我们有两个表:Customers 和 Orders,其中 Customers 表记录了客户信息,Orders 表记录了客户的订单信息。这是一个典型的一对多关系,每个客户可以有多个订单。


[*] Customers 表:
CustomerID | CustomerName
-----------+-------------
1          | Alice
2          | Bob
3          | Charlie

[*] Orders 表:
OrderID | CustomerID | OrderAmount
--------+------------+------------
1       | 1          | 100
2       | 1          | 150
3       | 2          | 200
4       | 2          | 250
5       | 3          | 300

在这种场景中,实验INNER JOIN查询:
SELECT Customers.CustomerID, Customers.CustomerName, Orders.OrderID, Orders.OrderAmount
FROM Customers
INNER JOIN Orders ON Customers.CustomerID = Orders.CustomerID;
返回的结果为:
CustomerID | CustomerName | OrderID | OrderAmount
-----------+--------------+---------+------------
1          | Alice      | 1       | 100
1          | Alice      | 2       | 150
2          | Bob          | 3       | 200
2          | Bob          | 4       | 250
3          | Charlie      | 5       | 300
示例:多对多关系

假设我们有三个表:Students, Courses 和 Enrollments,其中 Students 表记录学生信息,Courses 表记录课程信息,Enrollments 表记录学生与课程的注册关系。


[*] Students 表:
StudentID | StudentName
----------+------------
1         | Alice
2         | Bob
3         | Charlie

[*] Courses 表:
CourseID | CourseName
---------+-----------
1      | Math
2      | Science
3      | History
4      | Art

[*] Enrollments 表:
EnrollmentID | StudentID | CourseID
-------------+-----------+---------
1            | 1         | 1
2            | 1         | 2
3            | 2         | 2
4            | 2         | 3
5            | 3         | 3
6            | 3         | 4

在这种场景中,实验多对多关系的INNER JOIN查询:
SELECT Students.StudentID, Students.StudentName, Courses.CourseID, Courses.CourseName
FROM Students
INNER JOIN Enrollments ON Students.StudentID = Enrollments.StudentID
INNER JOIN Courses ON Enrollments.CourseID = Courses.CourseID;
返回的结果为:
StudentID | StudentName | CourseID | CourseName
----------+-------------+----------+-----------
1         | Alice       | 1      | Math
1         | Alice       | 2      | Science
2         | Bob         | 2      | Science
2         | Bob         | 3      | History
3         | Charlie   | 3      | History
3         | Charlie   | 4      | Art
InnerJoin关联结果的总结

通过上述示例,我们可以总结出INNER JOIN在不同关系类型中的行为规律:


[*]一对多关系:INNER JOIN返回的行数主要取决于“多”方的行数,即子表的行数和匹配关系。最终的结果集行数等于父表中每一行在子表中的均匀匹配数与父表行数的乘积。
[*]多对多关系:INNER JOIN返回的行数通常等于中心表的行数。中心表记录了两表之间的所有关系,因此结果集行数等于中心表的记录数。
三、InnerJoin与其他Join关联查询结果的异同

在关系数据库中,除了INNER JOIN,还有其他类型的JOIN,比方LEFT JOIN、RIGHT JOIN和FULL JOIN。了解它们之间的差异对于选择合适的JOIN类型至关重要。
LEFT JOIN(或LEFT OUTER JOIN)

LEFT JOIN返回左表中的所有行,即使右表中没有匹配的行。对于没有匹配的行,右表的列将包罗NULL值。
示例
假设我们有两个表:Customers 和 Orders。
SELECT Customers.CustomerID, Customers.CustomerName, Orders.OrderID, Orders.OrderAmount
FROM Customers
LEFT JOIN Orders ON Customers.CustomerID = Orders.CustomerID;
返回的结果大概包罗没有订单的客户:
CustomerID | CustomerName | OrderID | OrderAmount
-----------+--------------+---------+------------
1          | Alice      | 1       | 100
1          | Alice      | 2       | 150
2          | Bob          | 3       | 200
2          | Bob          | 4       | 250
3          | Charlie      | 5       | 300
4          | David      | NULL    | NULL RIGHT JOIN(或RIGHT OUTER JOIN)

RIGHT JOIN返回右表中的所有行,即使左表中没有匹配的行。对于没有匹配的行,左表的列将包罗NULL值。
示例
SELECT Customers.CustomerID, Customers.CustomerName, Orders.OrderID, Orders.OrderAmount
FROM Customers
RIGHT JOIN Orders ON Customers.CustomerID = Orders.CustomerID;
返回的结果大概包罗没有匹配客户的订单:
CustomerID | CustomerName | OrderID | OrderAmount
-----------+--------------+---------+------------
1          | Alice      | 1       | 100
1          | Alice      | 2       | 150
2          | Bob          | 3       | 200
2          | Bob          | 4       | 250
3          | Charlie      | 5       | 300
NULL       | NULL         | 6       | 350 FULL JOIN(或FULL OUTER JOIN)

FULL JOIN返回两个表中的所有行。如果没有匹配的行,则相应表的列将包罗NULL值。
示例
SELECT Customers.CustomerID, Customers.CustomerName, Orders.OrderID, Orders.OrderAmount
FROM Customers
FULL JOIN Orders ON Customers.CustomerID = Orders.CustomerID;
返回的结果大概包罗所有客户和订单,包罗没有匹配的行:
CustomerID | CustomerName | OrderID | OrderAmount
-----------+--------------+---------+------------
1          | Alice      | 1       | 100
1          | Alice      | 2       | 150
2          | Bob          | 3       | 200
2          | Bob          | 4       | 250
3          | Charlie      | 5       | 300
4          | David      | NULL    | NULLNULL       | NULL         | 6       | 350 CROSS JOIN

CROSS JOIN返回两个表的笛卡尔积,即每个表中的每一行都与另一个表中的每一行进行组合。
示例
SELECT Customers.CustomerID, Customers.CustomerName, Orders.OrderID, Orders.OrderAmount
FROM Customers
CROSS JOIN Orders;
返回的结果为:
CustomerID | CustomerName | OrderID | OrderAmount
-----------+--------------+---------+------------
1          | Alice      | 1       | 100
1          | Alice      | 2       | 150
1          | Alice      | 3       | 200
1          | Alice      | 4       | 250
1          | Alice      | 5       | 300
2          | Bob          | 1       | 100
2          | Bob          | 2       | 150
2          | Bob          | 3       | 200
2          | Bob          | 4       | 250
2          | Bob          | 5       | 300
3          | Charlie      | 1       | 100
3          | Charlie      | 2       | 150
3          | Charlie      | 3       | 200
3          | Charlie      | 4       | 250
3          | Charlie      | 5       | 300
四、InnerJoin 总结

INNER JOIN是SQL查询中最常用的JOIN类型之一,它仅返回两个表中匹配的行。在理解INNER JOIN时,必要重点关注以下几点:

[*]界说和概念:INNER JOIN用于返回两个表中基于指定条件匹配的行。
[*]盘算方法:在一对多和多对多关系中,INNER JOIN的结果集行数取决于匹配条件和表之间的关系类型。
[*]与其他JOIN的比较:INNER JOIN与LEFT JOIN、RIGHT JOIN、FULL JOIN和CROSS JOIN在行为和返回结果上存在明显差异,选择合适的JOIN类型对于精确查询至关重要。
通过理解这些概念和技能细节,您可以更高效地使用INNER JOIN进行数据查询和分析,办理复杂的数据处理需求。在实际应用中,建议通过动手练习和阅读相关文档来进一步巩固所学知识,并在项目中机动应用。
https://i-blog.csdnimg.cn/direct/c56c0ffe412d45d38013fa49de9af8bd.gif

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 深入理解SQL中的INNER JOIN操纵