可以将一个查询的结果用作另一个查询的输入。可以将子查询的结果用作使用 IN( ) 函数、EXISTS 运算符或 FROM 子句的语句。
若要创建子查询,可以在“SQL”窗格中将其直接输入,或者复制一个查询并将其粘贴到另一个查询中。
![]() |
---|
对于在以下说明中使用的某些 Visual Studio 用户界面元素,您的计算机可能会显示不同的名称或位置。这些元素取决于您所使用的 Visual Studio 版本和您所使用的设置。有关更多信息,请参见 Visual Studio 设置。 |
在“SQL”窗格中定义子查询
创建主查询。
在“SQL”窗格中选择 SQL 语句,再使用**“复制”**将该查询移动到剪贴板上。
启动新查询,再使用**“粘贴”**将第一个查询移动到新查询的 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)