问题描述
这是我在阅读Mick的《SQL进阶教程》第一章第2小节时遇到的一道思考题。
原问题如下:
作者已经给出了用自连接的解决方法以及查询的结果:
随后,抛出了一个思考题:如何用关联子查询来得到相同的结果呢?
方法1:使用聚合函数COUNT
当我们把这个表跟它自己做关联子查询的时候,就可以得出各种价格的记录数量。如果价格是独特的,那数量就是1,如果存在等价的水果,那数量就大于1.利用这个条件,可以查出符合条件的记录。
SELECT P1.name, P1.price
FROM Products AS P1
WHERE 1 < (SELECT COUNT(*)
FROM Products AS P2
WHERE P2.price=P1.price);
方法2:使用谓词EXISTS
我们要查询的内容可以描述为“满足价格相同并且名字不同的水果”,而我一直回避使用的EXISTS谓词的功能正是判断是否存在满足某种条件的记录。
SELECT P1.name, P1.price
FROM Products AS P1
-- 因为EXISTS只是用来判断有没有,所以子查询里SELECT什么列都行,比较方便的就是SELECT *
WHERE EXISTS (SELECT *
FROM Products AS P2
WHERE P1.price = P2.price
-- 水果名称不同在子查询的连接条件里声明
AND P1.name <> P2.name);