我很难把头绕在下面的代码上:
SELECT
productCode, productName, buyPrice
FROM
products a
WHERE
1 =
(
SELECT COUNT(productCode)
FROM products b
WHERE b.buyPrice > a.buyPrice
);特别是这一部分:
WHERE
1 =
(
SELECT COUNT(productCode)
FROM products b
WHERE b.buyPrice > a.buyPrice # descending order
);问题:1.语句中的选择过程是什么? 2. WHERE b.buyPrice > a.buyPrice如何匹配行b.buyPrice与a.buyPrice?3. WHERE 1 = (SELECT...在这一点上1的含义是什么?
发布于 2020-06-07 23:04:43
对于表中第二昂贵的产品,WHERE子句中的“谓词”将计算为true。
它使用一个“关联子查询”--对于每一行--查找所有比当前行更昂贵的产品,然后对它们进行计数;这就是相关子查询的工作方式。谓词验证此计数准确为1。
如果您注意到该表被使用了两次,但是使用了不同的别名,a和b可以准确地引用这些比较。
https://stackoverflow.com/questions/62252750
复制相似问题