MySQL ANY 和 ALL 运算符
MySQL ANY 和 ALL 运算符
MySQL 的 ANY
和 ALL
运算符允许您执行单个列值与一系列其他值的比较。
ANY 运算符
ANY
运算符
- 返回布尔值作为结果
- 如果子查询中的任意值满足条件,则返回 TRUE
ANY
表示如果操作对范围内的任意值都为真,则条件将为真。
ANY 语法
SELECT 列名(s)
FROM 表名
WHERE 列名 运算符 ANY
(SELECT 列名
FROM 表名
WHERE 条件);
注意:运算符 必须是标准比较运算符 (=, <>, !=, >, >=, <, 或 <=).
ALL 运算符
The ALL
运算符
- 返回布尔值作为结果
- 如果子查询中的所有值都满足条件,则返回 TRUE
- 用于
SELECT
,WHERE
和HAVING
语句
ALL
表示只有当操作对范围内所有值都为真时,条件才为真。
ALL 语法与 SELECT 一起使用
SELECT ALL 列名(s)
FROM 表名
WHERE 条件;
ALL 语法与 WHERE 或 HAVING 一起使用
SELECT 列名(s)
FROM 表名
WHERE 列名 运算符 ALL
(SELECT 列名
FROM 表名
WHERE 条件);
注意:运算符 必须是标准比较运算符 (=, <>, !=, >, >=, <, 或 <=).
演示数据库
以下是 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 语句列出了在 OrderDetails 表中找到的任何记录的 Quantity 等于 10 的 ProductName(这将返回 TRUE,因为 Quantity 列中有一些值为 10)
示例
SELECT ProductName
FROM Products
WHERE ProductID = ANY
(SELECT ProductID
FROM OrderDetails
WHERE Quantity = 10);
自己试试 »
以下 SQL 语句列出了在 OrderDetails 表中找到的任何记录的 Quantity 大于 99 的 ProductName(这将返回 TRUE,因为 Quantity 列中有一些值大于 99)
示例
SELECT ProductName
FROM Products
WHERE ProductID = ANY
(SELECT ProductID
FROM OrderDetails
WHERE Quantity > 99);
自己试试 »
以下 SQL 语句列出了在 OrderDetails 表中找到的任何记录的 Quantity 大于 1000 的 ProductName(这将返回 FALSE,因为 Quantity 列中没有值大于 1000)
示例
SELECT ProductName
FROM Products
WHERE ProductID = ANY
(SELECT ProductID
FROM OrderDetails
WHERE Quantity > 1000);
自己试试 »
SQL ALL 示例
以下 SQL 语句列出了所有产品名称
以下 SQL 语句列出了在 OrderDetails 表中所有记录的 Quantity 都等于 10 的 ProductName。当然,这将返回 FALSE,因为 Quantity 列中有很多不同的值(不仅仅是 10 的值)
示例
SELECT ProductName
FROM Products
WHERE ProductID = ALL
(SELECT ProductID
FROM OrderDetails
WHERE Quantity = 10);
自己试试 »