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 关键字。