MySQL ANY 和 ALL 运算符

ANYALL 运算符允许你在单列值和其他值范围之间进行比较。

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);

注意:运算符必须是标准比较运算符(=、<>、!=、>、>=、< 或 <=)。

ALL 运算符

ALL 运算符:

  • 返回一个布尔值作为结果;
  • 如果子查询中的所有值都满足条件,则返回 TRUE;
  • SELECTWHEREHAVING 语句一起使用;

ALL 表示只有当范围内的所有值都满足操作条件时,该条件才为真。

与 SELECT 一起使用的 ALL 语法:

SELECT ALL column_name(s)
FROM table_name
WHERE condition;

与 WHERE 或 HAVING 一起使用的 ALL 语法:

SELECT column_name(s)
FROM table_name
WHERE column_name operator ALL
  (SELECT column_name
  FROM table_name
  WHERE condition);

注意:运算符必须是标准比较运算符(=、<>、!=、>、>=、< 或 <=)。

演示数据库

以下是 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 语句列出所有产品名称:

实例

SELECT ALL ProductName
FROM Products
WHERE TRUE;

亲自试一试

如果 OrderDetails 表中的所有记录的 Quantity 都等于 10,以下 SQL 语句会列出 ProductName。这当然会返回 FALSE,因为 Quantity 列有许多不同的值(不仅仅是 10 的值):

实例

SELECT ProductName
FROM Products
WHERE ProductID = ALL
  (SELECT ProductID
  FROM OrderDetails
  WHERE Quantity = 10);

亲自试一试