MySQL——多表操作(四)(2)带 EXISTS 关键字的子查询

         EXISTS 关键字后面的参数可以是任意一个子查询,这个子查询的作用相当于测试,坏产生任何数据,只返回 TRUE 或 FALSE,当返回值为 TRUE 时,外层查询才会执行。

        例如,查询 employee 表中是否存在年龄大于 21岁的员工,如果存在,则查询 department 表中的所有记录,SQL 语句如下:

SELECT * FROM department WHERE EXISTS(select did from employee where age>21);

        上述语句执行成功后,结果如下:

mysql> SELECT * FROM department WHERE EXISTS(select did from employee where age>21);
+-----+-----------+
| did | dname     |
+-----+-----------+
|   1 | 网络部    |
|   2 | 媒体部    |
|   3 | 研发部    |
|   5 | 人事部    |
+-----+-----------+
4 rows in set (0.01 sec)

        由于 employee 表中有年龄大于 21 岁的员工,因此子查询的返回结果为 TRUE,所以外的查询语句会执行,即查询出所有的部门信息。需要注意的是,EXISTS 关键字比 IN 关键字的运行效率高,所以在实际开发中,特别是大数据量时,推荐使用 EXISTS 关键字。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Code repairman

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

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值