SQL 入门教程:子查询「终于解决」

SQL 入门教程:子查询「终于解决」目录汇总:SQL 入门教程:面向萌新小白的零基础入门教程 SELECT 语句 是 SQL 的查询。我们迄今为止所看到的所有 SELECT 语句都是简单查询,即从单个数据库表中检索数据的单条语句。 查询

SQL 入门教程:子查询

目录
  • 一、利用子查询进行过滤
  • 请参阅

目录汇总:SQL 入门教程:面向萌新小白的零基础入门教程

SELECT 语句 是 SQL 的查询。我们迄今为止所看到的所有 SELECT 语句都是简单查询,即从单个数据库表中检索数据的单条语句。

查询(query)

任何 SQL 语句都是查询。但此术语一般指 SELECT 语句。

SQL 还允许创建子查询(subquery),即嵌套在其他查询中的查询。为什么要这样做呢?理解这个概念的最好方法是考察几个例子。

一、利用子查询进行过滤

本教程所有部分中使用的数据库表都是关系表(关于每个表及关系的描述,请参阅 样例表脚本)。订单存储在两个表中。每个订单包含订单编号、客户 ID、订单日期,在 Orders 表中存储为一行。各订单的物品存储在相关的 OrderItems 表中。Orders 表不存储顾客信息,只存储顾客 ID。顾客的实际信息存储在 Customers 表中。

现在,假如需要列出订购物品 RGAN01 的所有顾客,应该怎样检索?下面列出具体的步骤。

(1) 检索包含物品 RGAN01 的所有订单的编号。

(2) 检索具有前一步骤列出的订单编号的所有顾客的 ID。

(3) 检索前一步骤返回的所有顾客 ID 的顾客信息。

上述每个步骤都可以单独作为一个查询来执行。可以把一条 SELECT 语句返回的结果用于另一条 SELECT 语句的 WHERE 子句。

也可以使用子查询来把 3 个查询组合成一条语句。

第一条 SELECT 语句的含义很明确,它对 prod_id 为 RGAN01 的所有订单物品,检索其 order_num 列。输出列出了两个包含此物品的订单:

输入▼

SELECT order_num
FROM OrderItems
WHERE prod_id = "RGAN01";

输出▼

order_num
-----------
20007
20008

现在,我们知道了哪个订单包含要检索的物品,下一步查询与订单 20007 和 20008 相关的顾客 ID。利用 IN 操作符 介绍的 IN 子句,编写如下的 SELECT 语句:

输入▼

SELECT cust_id
FROM Orders
WHERE order_num IN (20007,20008);

输出▼

cust_id
----------
1000000004
1000000005

现在,结合这两个查询,把第一个查询(返回订单号的那一个)变为子查询。请看下面的 SELECT 语句:

输入▼

SELECT cust_id
FROM Orders
WHERE order_num IN (SELECT order_num
                    FROM OrderItems
                    WHERE prod_id = "RGAN01");

输出▼

cust_id
----------
1000000004
1000000005

分析▼

SELECT 语句中,子查询总是从内向外处理。在处理上面的 SELECT 语句时,DBMS 实际上执行了两个操作。

首先,它执行下面的查询:

SELECT order_num FROM orderitems WHERE prod_id="RGAN01"

此查询返回两个订单号:20007 和 20008。然后,这两个值以 IN 操作符要求的逗号分隔的格式传递给外部查询的 WHERE 子句。外部查询变成:

SELECT cust_id FROM orders WHERE order_num IN (20007,20008)

可以看到,输出是正确的,与前面硬编码 WHERE 子句所返回的值相同。

提示:格式化 SQL

包含子查询的 SELECT 语句难以阅读和调试,它们在较为复杂时更是如此。如上所示,把子查询分解为多行并进行适当的缩进,能极大地简化子查询的使用。

顺便一提,这就是颜色编码起作用的地方,好的 DBMS 客户端正是出于这个原因使用了颜色代码 SQL。

现在得到了订购物品 RGAN01 的所有顾客的ID。下一步是检索这些顾客 ID 的顾客信息。检索两列的 SQL 语句为:

输入▼

SELECT cust_name, cust_contact
FROM Customers
WHERE cust_id IN (1000000004,1000000005);

可以把其中的 WHERE 子句转换为子查询,而不是硬编码这些顾客 ID:

输入▼

SELECT cust_name, cust_contact
FROM Customers
WHERE cust_id IN (SELECT cust_id
                  FROM Orders
                  WHERE order_num IN (SELECT order_num
                                      FROM OrderItems
                                      WHERE prod_id = "RGAN01"));

输出▼

cust_name                         cust_contact
-----------------------------     --------------------
Fun4All                           Denise L. Stephens
The Toy Store                     Kim Howard

分析▼

为了执行上述 SELECT 语句,DBMS 实际上必须执行三条 SELECT 语句。最里边的子查询返回订单号列表,此列表用于其外面的子查询的 WHERE 子句。外面的子查询返回顾客 ID 列表,此顾客 ID 列表用于最外层查询的 WHERE 子句。最外层查询返回所需的数据。

可见,在 WHERE 子句中使用子查询能够编写出功能很强且很灵活的 SQL 语句。对于能嵌套的子查询的数目没有限制,不过在实际使用时由于性能的限制,不能嵌套太多的子查询。

注意:只能是单列

作为子查询的 SELECT 语句只能查询单个列。企图检索多个列将返回错误。

注意:子查询和性能

这里给出的代码有效,并且获得了所需的结果。但是,使用子查询并不总是执行这类数据检索的最有效方法。

请参阅

  • 子查询
  • 作为计算字段使用子查询
  • 子查询练习题

(完)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5935.html

(0)
上一篇 2023-04-20
下一篇 2023-04-20

相关推荐

  • Spark内存管理[通俗易懂]

    Spark内存管理[通俗易懂]1、spark的一大特性就是基于内存计算,Driver只保存任务的宏观性的元数据,数据量较小,且在执行过程中基本不变,不做重点分析,而真正的计算任务Task分布在各个Executor中,其中的内存数据

    2023-01-30
    100
  • Python列表操作:实现对列表数据的增、删、查、改操作

    Python列表操作:实现对列表数据的增、删、查、改操作Python中的列表是一种有序的集合,它可以保存任意数量的Python对象。列表使用方括号[]来表示,其中的元素用逗号隔开。在Python中,列表是非常常见的数据结构,也是处理数据的重要基础。在本文中,我们将对Python列表的增、删、查、改操作进行详细介绍。

    2024-01-11
    62
  • Access2010查阅向导报错问题解决方法「终于解决」

    Access2010查阅向导报错问题解决方法「终于解决」
    系统:win7家庭版 Access版本:Office2010专业版64位(x64) 报错描述:(如下图) 解决过程:我在网上看了很多解决方法,都治标不治本,…

    2023-04-08
    105
  • Python Tkinter Text Widget:如何创建可编辑文本框

    Python Tkinter Text Widget:如何创建可编辑文本框Python的Tkinter库提供了一个多功能的Text Widget,可用于在GUI应用程序中创建文本编辑器。文本框不仅可以显示纯文本,还可以显示HTML和RTF文本。此外,您还可以为文本框添加多种属性和样式,例如颜色、字体和对齐方式等。

    2024-01-16
    61
  • 数据库2.0_1.12数据库

    数据库2.0_1.12数据库数据库2.0 ‘MySQL存储引擎介绍’ ‘MySQL基础数据类型’ ‘MySQL表的完整性约束’ ‘MySQL数据库初识’ ‘MySQL的库表详细操作’ ‘MySQL的逻辑查询语句的执行

    2022-12-28
    110
  • Python:函数和模块的区别及应用

    Python:函数和模块的区别及应用在Python中,函数和模块都是非常重要的概念。虽然有些相似,但实际上两者之间有一些根本性的区别。本文将从多个方面对Python函数和模块进行详细的阐述,让读者更好地理解两者的区别及应用。

    2024-03-20
    31
  • Python元组和列表:数据容器的不同用法和特点

    Python元组和列表:数据容器的不同用法和特点Python中,元组和列表都是常见的数据容器类型。但两者在定义、操作和使用上有很大的不同。元组是由逗号分隔开的多个元素组成,且一旦创建,元素不可更改。列表则是由方括号括起来的一组元素,可以修改、删除和添加。创建元组用小括号,创建列表用方括号,如下所示:

    2024-01-01
    69
  • Redis知识点(一)[亲测有效]

    Redis知识点(一)[亲测有效]Redis 是什么 总结下 Redis 的定义和特点: Redis 是 C 语言开发的一个开源的(遵从 BSD 协议)高性能键值对(key-value)的内存数据库,可以用作数据库、缓存、消息中间件…

    2023-02-13
    108

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注