sql中all和any区别-SQL

SQL 中 ALL 和 ANY 的区别

开门见山回答:

SQL 中的 ALL 和 ANY 是两个不同的关键字,用于比较子查询的结果与主查询的结果。

详细回答:

1. ALL

ALL 运算符检查子查询是否对主查询的每一行都返回真值。如果子查询对所有行都返回真值,则 ALL 比较返回真值;否则返回假值。

示例:

SELECT *
FROM customer
WHERE ALL (SELECT 1 FROM purchase WHERE customer_id = customer.id);
登录后复制

该查询返回所有客户,其中每一个都至少进行了一次购买。

2. ANY

ANY 运算符检查子查询是否对主查询的任何一行返回真值。如果子查询对至少一行返回真值,则 ANY 比较返回真值;否则返回假值。

示例:

SELECT *
FROM customer
WHERE ANY (SELECT 1 FROM purchase WHERE customer_id = customer.id);
登录后复制

该查询返回所有客户,其中至少有一个进行了购买。

总结:

运算符 描述
ALL 子查询必须对所有行返回真值
ANY 子查询必须对至少一行返回真值

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。