如何:创建子查询

可以将一个查询的结果用作另一个查询的输入。可以将子查询的结果用作使用 IN( ) 函数、EXISTS 运算符或 FROM 子句的语句。

若要创建子查询,可以在“SQL”窗格中将其直接输入,或者复制一个查询并将其粘贴到另一个查询中。

说明说明

对于在以下说明中使用的某些 Visual Studio 用户界面元素,您的计算机可能会显示不同的名称或位置。这些元素取决于您所使用的 Visual Studio 版本和您所使用的设置。有关更多信息,请参见 Visual Studio 设置

在“SQL”窗格中定义子查询

  1. 创建主查询。

  2. 在“SQL”窗格中选择 SQL 语句,再使用**“复制”**将该查询移动到剪贴板上。

  3. 启动新查询,再使用**“粘贴”**将第一个查询移动到新查询的 WHERE 或 FROM 子句中。

    例如,假设有 products 和 suppliers 两个表,您希望创建显示瑞典供应商的所有产品的查询。在 suppliers 表中创建第一个查询以查找所有的瑞典供应商:

    SELECT supplier_id
    FROM supplier
    WHERE (country = 'Sweden')
    

    使用“复制”命令将此查询移动到剪贴板中。用 products 表创建第二个查询,该查询列出您需要的产品信息:

    SELECT product_id, supplier_id, product_name
    FROM products
    

    在“SQL”窗格中,将 WHERE 子句添加到第二个查询中,然后从剪贴板粘贴第一个查询。用括号将第一个查询括起来,以使最终结果如下所示:

    SELECT product_id, supplier_id, product_name
    FROM products
    WHERE supplier_id IN
       (SELECT supplier_id
      FROM supplier
      WHERE (country = 'Sweden'))
    

请参见

概念

支持的查询类型 (Visual Database Tools)

查询中的表达式

其他资源

指定搜索条件