首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >WHERE子句如何在以下实例中工作?

WHERE子句如何在以下实例中工作?
EN

Stack Overflow用户
提问于 2020-06-07 22:59:42
回答 2查看 32关注 0票数 1

我很难把头绕在下面的代码上:

代码语言:javascript
复制
SELECT
    productCode, productName, buyPrice
FROM
    products a
WHERE
    1 =
        (
        SELECT COUNT(productCode)
        FROM products b
        WHERE b.buyPrice > a.buyPrice
        );

特别是这一部分:

代码语言:javascript
复制
WHERE
    1 =
        (
        SELECT COUNT(productCode)
        FROM products b
        WHERE b.buyPrice > a.buyPrice # descending order
        );

问题:1.语句中的选择过程是什么? 2. WHERE b.buyPrice > a.buyPrice如何匹配行b.buyPricea.buyPrice?3. WHERE 1 = (SELECT...在这一点上1的含义是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-06-07 23:04:30

该查询为您提供了价格第二高的产品,包括领带。

关联子查询计算同一表中有多少行的价格高于当前行中的行,即需要为1。

如果不涉及任何联系,您可以使用限制行的查询来表示:

代码语言:javascript
复制
select *
from products
order by buyPrice desc
limit 1, 1

但这并不能恰当地处理关系。还要注意的是,查询并没有正确地管理顶级链接:如果有超过一个产品的最高价格,那么您的查询就会出现空,这可能不是您想要的。

在支持窗口函数的MySQL 8.0中,使用dense_rank()可以更容易、更安全地表述这一点:

代码语言:javascript
复制
select *
from (
    select p.*, dense_rank() over(order by buyPrice desc) rn
    from products p
) p
where rn = 2
票数 2
EN

Stack Overflow用户

发布于 2020-06-07 23:04:43

对于表中第二昂贵的产品,WHERE子句中的“谓词”将计算为true。

它使用一个“关联子查询”--对于每一行--查找所有比当前行更昂贵的产品,然后对它们进行计数;这就是相关子查询的工作方式。谓词验证此计数准确为1

如果您注意到该表被使用了两次,但是使用了不同的别名,ab可以准确地引用这些比较。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62252750

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档