SQL ANY 和 ALL 運算子
SQL ANY 和 ALL 運算子
SQL 的 ANY 和 ALL 運算子允許您對單個列值與一系列其他值執行比較。
SQL ANY 運算子
ANY 運算子
- 返回一個布林值作為結果
- 如果子查詢值中的任何一個滿足條件,則返回 TRUE
ANY 表示如果該操作對範圍內的任何一個值都為真,則該條件為真。
ANY 語法
SELECT column_name(s)
FROM table_name
WHERE column_name operator ANY
(SELECT column_name
FROM table_name
WHERE condition);注意:operator 必須是一個標準的比較運算子 (=, <>, !=, >, >=, <, 或 <=)。
SQL ALL 運算子
ALL 運算子
- 返回一個布林值作為結果
- 如果子查詢值中的所有值都滿足條件,則返回 TRUE
- 與
SELECT、WHERE和HAVING語句一起使用
ALL 表示只有當該操作對範圍內的所有值都為真時,該條件才為真。
ALL 語法與 SELECT
SELECT ALL column_name(s)
FROM table_name
WHERE condition;ALL 語法與 WHERE 或 HAVING
SELECT column_name(s)
FROM table_name
WHERE column_name operator ALL
(SELECT column_name
FROM table_name
WHERE condition);注意:operator 必須是一個標準的比較運算子 (=, <>, !=, >, >=, <, 或 <=)。
演示資料庫
以下是從 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 示例
以下 SQL 語句列出了 ProductName,如果它在 OrderDetails 表中找到任何 Quantity 等於 10 的記錄(這將返回 TRUE,因為 Quantity 列有一些值為 10)。
示例
SELECT ProductName
FROM Products
WHERE ProductID = ANY
(SELECT ProductID
FROM OrderDetails
WHERE Quantity = 10);
自己動手試一試 »
以下 SQL 語句列出了 ProductName,如果它在 OrderDetails 表中找到任何 Quantity 大於 99 的記錄(這將返回 TRUE,因為 Quantity 列有一些值大於 99)。
示例
SELECT ProductName
FROM Products
WHERE ProductID = ANY
(SELECT ProductID
FROM OrderDetails
WHERE Quantity > 99);
自己動手試一試 »
以下 SQL 語句列出了 ProductName,如果它在 OrderDetails 表中找到任何 Quantity 大於 1000 的記錄(這將返回 FALSE,因為 Quantity 列沒有大於 1000 的值)。
示例
SELECT ProductName
FROM Products
WHERE ProductID = ANY
(SELECT ProductID
FROM OrderDetails
WHERE Quantity > 1000);
自己動手試一試 »
SQL ALL 示例
以下 SQL 語句列出了所有產品名稱
以下 SQL 語句列出了 ProductName,如果 OrderDetails 表中的所有記錄的 Quantity 都等於 10。當然,這將返回 FALSE,因為 Quantity 列有許多不同的值(不僅僅是 10)。
示例
SELECT ProductName
FROM Products
WHERE ProductID = ALL
(SELECT ProductID
FROM OrderDetails
WHERE Quantity = 10);
自己動手試一試 »