SQL ANY 与 ALL 操作符
本章节讲解 SQL ANY 与 ALL 操作符的用法。
SQL ANY 与 ALL 操作符
ANY 与 ALL 运算符允许您在单个列值和一系列其他值之间进行比较。
SQL ANY 操作符
ANY 操作符:
- 返回一个布尔值作为结果
- 如果任何子查询值满足条件,则返回 TRUE
ANY 表示如果范围内的任何值的操作为真,则条件为真。
ANY 语法
SELECT column_name(s)FROM table_nameWHERE column_name operator ANY(SELECT column_nameFROM table_nameWHERE condition );
注意:运算符必须是标准比较运算符 (=, <>, !=, >, >=, <, or <=).
SQL ALL 操作符
ALL 操作符:
- 返回一个布尔值作为结果
- 如果所有子查询值都满足条件,则返回 TRUE
- 通常与
SELECT,WHERE和HAVING语句一起使用
ALL 表示仅当范围内所有值的操作均为真时,条件才为真。
ALL 与 SELECT 一起使用的语法
SELECT ALL column_name(s)FROM table_nameWHERE condition ;
ALL 与 WHERE 或 HAVING 一起使用的语法
SELECT column_name(s)FROM table_nameWHERE column_name operator ALL(SELECT column_nameFROM table_nameWHERE condition );
注意:运算符必须是标准比较运算符 (=, <>, !=, >, >=, <, or <=).
Demo 数据库
以下是从 Northwind 实例数据库中的 "Products" 表中选择的内容:
| ProductID | ProductName | SupplierID | CategoryID | Unit | Price |
|---|---|---|---|---|---|
| 1 | Chais | 1 | 1 | 10 boxes x 20 bags | 18 |
| 2 | Chang | 1 | 1 | 24 - 12 oz bottles | 19 |
| 3 | Aniseed Syrup | 1 | 2 | 12 - 550 ml bottles | 10 |
| 4 | Chef Anton's Cajun Seasoning | 2 | 2 | 48 - 6 oz jars | 22 |
| 5 | Chef Anton's Gumbo Mix | 2 | 2 | 36 boxes | 21.35 |
| 6 | Grandma's Boysenberry Spread | 3 | 2 | 12 - 8 oz jars | 25 |
| 7 | Uncle Bob's Organic Dried Pears | 3 | 7 | 12 - 1 lb pkgs. | 30 |
| 8 | Northwoods Cranberry Sauce | 3 | 2 | 12 - 12 oz jars | 40 |
| 9 | Mishi Kobe Niku | 4 | 6 | 18 - 500 g pkgs. | 97 |
还有 “OrderDetails” 表中选择的内容:
| OrderDetailID | OrderID | ProductID | Quantity |
|---|---|---|---|
| 1 | 10248 | 11 | 12 |
| 2 | 10248 | 42 | 10 |
| 3 | 10248 | 72 | 5 |
| 4 | 10249 | 14 | 9 |
| 5 | 10249 | 51 | 40 |
| 6 | 10250 | 41 | 10 |
| 7 | 10250 | 51 | 35 |
| 8 | 10250 | 65 | 15 |
| 9 | 10251 | 22 | 6 |
| 10 | 10251 | 57 | 15 |
SQL ANY 实例
如果在 OrderDetails 表中发现任何记录的数量等于 10,则以下 SQL 语句将列出 ProductName(这将返回 TRUE,因为数量列的某些值为 10):
实例
SELECT ProductNameFROM ProductsWHERE ProductID = ANY(SELECT ProductIDFROM OrderDetailsWHERE Quantity = 10);
如果在 OrderDetails 表中发现任何记录的数量大于 99,则以下SQL语句将列出 ProductName(这将返回 TRUE,因为Quantity 列的某些值大于 99):
实例
SELECT ProductNameFROM ProductsWHERE ProductID = ANY(SELECT ProductIDFROM OrderDetailsWHERE Quantity > 99);
如果在 OrderDetails 表中发现任何记录的数量大于 1000,则以下SQL语句将列出 ProductName(这将返回 FALSE,因为Quantity 列没有大于 1000 的值):
实例
SELECT ProductNameFROM ProductsWHERE ProductID = ANY(SELECT ProductIDFROM OrderDetailsWHERE Quantity > 1000);
SQL ALL 实例
以下 SQL 语句列出了所有产品名称:
实例
SELECT ALL ProductNameFROM ProductsWHERE TRUE;
如果 OrderDetails 表中的所有记录的数量都等于 10,则以下 SQL 语句将列出 ProductName。这当然会返回 FALSE,因为 Quantity 列有许多不同的值(不仅仅是 10 的值):
实例
SELECT ProductNameFROM ProductsWHERE ProductID = ALL(SELECT ProductIDFROM OrderDetailsWHERE Quantity = 10);