首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
第4章 数据更新
4-1 数据的插入(INSERT语句的使用方法)
什么是INSERT
INSERT语句的基本语法
列清单的省略
插入NULL
插入默认值
从其他表中复制数据
4-2 数据的删除(DELETE语句的使用方法)
DROP TABLE语句和DELETE语句
DELETE语句的基本语法
指定删除对象的DELETE语句(搜索型DELETE)
4-3 数据的更新(UPDATE语句的使用方法)
UPDATE语句的基本语法
指定条件的UPDATE语句(搜索型UPDATE)
使用NULL进行更新
多列更新
4-4 事务
什么是事务
创建事务
ACID特性
第5章 复杂查询
5-1 视图
视图和表
创建视图的方法
视图的限制① ——定义视图时不能使用ORDER BY子句
视图的限制② ——对视图进行更新
删除视图
5-2 子查询
子查询和视图
子查询的名称
标量子查询
标量子查询的书写位置
使用标量子查询时的注意事项
5-3 关联子查询
普通的子查询和关联子查询的区别
关联子查询也是用来对集合进行切分的
结合条件一定要写在子查询中
第6章 函数、谓词、CASE表达式
6-1 各种各样的函数
函数的种类
算术函数
字符串函数
日期函数
转换函数
6-2 谓词
什么是谓词
LIKE谓词——字符串的部分一致查询
BETWEEN谓词——范围查询
IS NULL、IS NOT NULL——判断是否为NULL
IN谓词——OR的简便用法
使用子查询作为IN谓词的参数
EXIST谓词
6-3 CASE表达式
什么是CASE表达式
CASE表达式的语法
CASE表达式的使用方法
第7章 集合运算
7-1 表的加减法
什么是集合运算
表的加法——UNION
集合运算的注意事项
包含重复行的集合运算——ALL选项
选取表中公共部分——INTERSECT
记录的减法——EXCEPT
7-2 联结(以列为单位对表进行联结)
什么是联结
内联结——INNER JOIN
外联结——OUTER JOIN
3张以上的表的联结
交叉联结——CROSS JOIN
联结的特定语法和过时语法
当前位置:
首页>>
技术小册>>
SQL基础教程(中)
小册名称:SQL基础教程(中)
### 章节标题:内联结——INNER JOIN 在SQL(Structured Query Language,结构化查询语言)的广阔领域中,内联结(INNER JOIN)是一种强大的工具,用于从两个或多个表中基于共同的属性(通常是主键和外键关系)查询数据。它允许我们将不同表中的相关数据行组合起来,形成一张更丰富的结果表,这对于数据分析和报表生成至关重要。本章将深入探讨INNER JOIN的基本概念、语法、应用场景以及通过实例来展示其实际应用。 #### 一、INNER JOIN的基本概念 INNER JOIN,顾名思义,是一种“内”部联结操作,它仅返回两个或多个表中满足联结条件的那些行。换句话说,如果表A中的某行与表B中的某行基于指定的联结条件相匹配,那么这两行就会合并成结果集中的一行。如果某行在任何一个表中找不到匹配项,则该行不会出现在结果集中。 #### 二、INNER JOIN的语法 INNER JOIN的基本语法结构如下: ```sql SELECT columns FROM table1 INNER JOIN table2 ON table1.common_field = table2.common_field; ``` - `SELECT columns`:指定要从联结的表中检索的列。可以包括来自一个表或多个表的列。 - `FROM table1`:指定第一个表(或主表)。 - `INNER JOIN table2`:指定要与第一个表进行内联结的第二个表。 - `ON table1.common_field = table2.common_field`:定义联结条件,即两个表中用于匹配记录的字段。这个条件决定了哪些行会被包括在结果集中。 #### 三、INNER JOIN的应用场景 INNER JOIN在多种情况下都非常有用,特别是在处理具有关联数据的数据库表时。以下是一些常见的应用场景: 1. **员工与部门信息**:假设有两个表,一个包含员工信息(如员工ID、姓名、部门ID),另一个包含部门信息(如部门ID、部门名称)。使用INNER JOIN可以查询出每个员工及其所属部门的详细信息。 2. **订单与产品信息**:在电子商务系统中,订单表和产品表可能通过产品ID相关联。使用INNER JOIN可以查询出每个订单包含的产品详情,如产品名称、价格等。 3. **学生成绩与课程信息**:学生表、成绩表和课程表之间通过学生ID和课程ID等字段关联。INNER JOIN可以用来查询每个学生所选课程的成绩。 #### 四、INNER JOIN的实例 为了更直观地理解INNER JOIN,我们将通过几个具体的例子来展示其应用。 ##### 示例1:员工与部门信息 假设我们有两个表:`employees`(员工表)和`departments`(部门表)。 `employees`表结构: - employee_id(员工ID) - name(姓名) - department_id(部门ID) `departments`表结构: - department_id(部门ID) - department_name(部门名称) 我们要查询每个员工的姓名以及他们所属的部门名称。 ```sql SELECT employees.name, departments.department_name FROM employees INNER JOIN departments ON employees.department_id = departments.department_id; ``` 这个查询将返回所有在`employees`表中有对应`department_id`的行,并将这些行与`departments`表中相应的`department_id`匹配的行合并,最终得到包含员工姓名和部门名称的结果集。 ##### 示例2:订单与产品信息 假设我们有两个表:`orders`(订单表)和`products`(产品表)。 `orders`表结构: - order_id(订单ID) - product_id(产品ID) - quantity(数量) `products`表结构: - product_id(产品ID) - product_name(产品名称) - price(价格) 我们要查询每个订单包含的产品名称和数量。 ```sql SELECT orders.order_id, products.product_name, orders.quantity FROM orders INNER JOIN products ON orders.product_id = products.product_id; ``` 这个查询将返回所有在`orders`表中有对应`product_id`的行,并将这些行与`products`表中相应的`product_id`匹配的行合并,最终得到包含订单ID、产品名称和数量的结果集。 #### 五、INNER JOIN的变种 虽然标准的INNER JOIN已经足够强大,但在某些情况下,我们可能需要稍微调整查询以适应特定的需求。例如,SQL还允许使用隐式INNER JOIN,其语法上省略了`INNER JOIN`关键字,直接在`FROM`子句中列出表名,并在`WHERE`子句中指定联结条件。 ```sql SELECT employees.name, departments.department_name FROM employees, departments WHERE employees.department_id = departments.department_id; ``` 虽然这种写法在功能上等同于使用`INNER JOIN`,但现代SQL编程中更推荐使用显式的`INNER JOIN`语法,因为它更清晰、更易于维护。 #### 六、总结 INNER JOIN是SQL中处理关联数据的关键工具之一。通过联结两个或多个表,我们可以创建包含来自多个源的信息的复杂查询结果。掌握INNER JOIN的基本概念、语法和应用场景,对于进行数据分析和报表生成至关重要。希望本章的内容能够帮助你更好地理解和运用INNER JOIN,从而更有效地从数据库中提取有价值的信息。
上一篇:
什么是联结
下一篇:
外联结——OUTER JOIN
该分类下的相关小册推荐:
高性能的Postgres SQL
PostgreSQL入门教程
SQL基础教程(上)
SQL基础教程(下)