IN、ANY、ALL与SOME

本文介绍了如何在 SQL 查询中使用 IN, ALL, ANY 和 SOME 子查询来筛选数据。通过具体例子展示了这些关键字在 restaurant_ratings 表上的应用,包括如何查找特定范围内的评分以及如何对比集合中的最大或最小值。

restaurant_ratings表

使用IN:

1 SELECT `name`, rating FROM restaurant_ratings 
2 WHERE rating IN
3 (SELECT rating FROM restaurant_ratings
4 WHERE rating > 3 AND rating < 9);

结果:

使用ALL:

1 SELECT `name`, rating FROM restaurant_ratings 
2 WHERE rating > ALL
3 (SELECT rating FROM restaurant_ratings
4 WHERE rating > 3 AND rating < 9);

大于加上ALL可以找出任何大于集合中最大值的值,小于则相反。

结果:

使用ANY:

1 SELECT `name`, rating FROM restaurant_ratings 
2 WHERE rating > ANY
3 (SELECT rating FROM restaurant_ratings
4 WHERE rating > 3 AND rating < 9);

大于加上ANY可以找出任何大于集合中最小值的值,小于相反。

结果:

使用SOME:

在标准SQL语法中,SOME与ANY表示相同的意思,在MySQL中也是这样。

 

转载于:https://www.cnblogs.com/hell0x/p/5124523.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值