使用关联子查询查找局部不一致的列的SQL语句

问题描述

这是我在阅读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);

如果这篇博文帮到了你,就请给我点个吧(#^.^#)

有疑问也欢迎留言~博主最近比较忙,如果没有及时回复还请见谅

ヾ(◍°∇°◍)ノ゙

  • 0
    点赞
  • 0
    收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:终极编程指南 设计师:CSDN官方博客 返回首页
评论 1

打赏作者

宁宁Fingerstyle

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值