在mysql数据库中any、some、all逻辑运算符使用浅析
数据库  /  管理员 发布于 2年前   588
any,some,all 是 MySQL 当中的逻辑运算符,作用是将子查询返回的单列值的集合与查询的单个值作比较。
any,all,some 前面需跟比较运算符:
>, >=, <, <=, !=, =,但是这里的单个使用 = 号的情况只有子集的数据是单个值或者子集数据全部相同才能符合情况,如果子集是多个不同的就不满足,根据实际情况使用。
mysql> select * from chat_communication;
+----+--------+------------------+------+------------------+--------------+------------+--------+--------+------+
| id | fromid | fromname | toid | toname | content | time | shopid | isread | type |
+----+--------+------------------+------+------------------+--------------+------------+--------+--------+------+
| 1 | 85 | Love violet life | 87 | 大金 | 你好 | 1517888705 | NULL | 1 | 1 |
| 2 | 87 | 大金 | 85 | Love violet life | 你也好 | 1517888712 | NULL | 1 | 1 |
| 3 | 89 | 雨薇 | 87 | 大金 | 你在干嘛 | 1517888760 | NULL | 1 | 1 |
| 4 | 85 | Love violet life | 87 | 大金 | 你还在吗 | 1517888797 | NULL | 0 | 1 |
| 5 | 85 | Love violet life | 87 | 大金 | 订单 | 1517888872 | NULL | 0 | 1 |
+----+--------+------------------+------+------------------+--------------+------------+--------+--------+------+
5 rows in set (0.00 sec)
all逻辑运算符
例如:
select …from …where c > all(…)
表示 c 列中的值必须要大于子查询集的每一个值,即必须要大于子查询集的最大值;
如果是小于号即小于子查询集的最小值。同理可以推出其它的比较运算符的情况。
示例:
列中的值必须要大于子查询集的每一个值。
查询 fromid 大于 fromid = 85 所有数据。
SELECT
*
FROM
chat_communication
WHERE
fromid > ALL (
SELECT
fromid
FROM
chat_communication
WHERE
fromid = 85
);
+----+--------+----------+------+------------------+--------------+------------+--------+--------+------+
| id | fromid | fromname | toid | toname | content | time | shopid | isread | type |
+----+--------+----------+------+------------------+--------------+------------+--------+--------+------+
| 2 | 87 | 大金 | 85 | Love violet life | 你也好 | 1517888712 | NULL | 1 | 1 |
| 3 | 89 | 雨薇 | 87 | 大金 | 你在干嘛 | 1517888760 | NULL | 1 | 1 |
+----+--------+----------+------+------------------+--------------+------------+--------+--------+------+
2 rows in set (0.01 sec)
any和some运算符
any和some作用是一样的。
例如
select…from…where c > any(…)
或者
select …from …where c > some(…)
表示 c 列中的值要大于子查询中的任意一个值,即必须要大于子查询集中的最小值。
同理可以推出其它的比较运算符的情况。
示例: 查询 fromid = 87 至少大于 fromid = 85 的数据
SELECT
*
FROM
chat_communication
WHERE
fromid = 87
AND fromid > ANY (
SELECT
fromid
FROM
chat_communication
WHERE
fromid = 85
);
+----+--------+----------+------+------------------+-----------+------------+--------+--------+------+
| id | fromid | fromname | toid | toname | content | time | shopid | isread | type |
+----+--------+----------+------+------------------+-----------+------------+--------+--------+------+
| 2 | 87 | 大金 | 85 | Love violet life | 你也好 | 1517888712 | NULL | 1 | 1 |
+----+--------+----------+------+------------------+-----------+------------+--------+--------+------+
1 row in set (0.00 sec)
SELECT
*
FROM
chat_communication
WHERE
fromid = 87
AND fromid > SOME (
SELECT
fromid
FROM
chat_communication
WHERE
fromid = 85
);
+----+--------+----------+------+------------------+-----------+------------+--------+--------+------+
| id | fromid | fromname | toid | toname | content | time | shopid | isread | type |
+----+--------+----------+------+------------------+-----------+------------+--------+--------+------+
| 2 | 87 | 大金 | 85 | Love violet life | 你也好 | 1517888712 | NULL | 1 | 1 |
+----+--------+----------+------+------------------+-----------+------------+--------+--------+------+
1 row in set (0.00 sec)
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号