当前位置: 首页 > article >正文

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

        子查询是指一个查询语句嵌套在另一个查询语句内部的查询。它可以嵌套在SELECT、SELECT、INTO 语句、INSERT…INTO 等语句中。在执行查询语句时,首会执行子查询中的语句,然后将返回的结果作为外层查询的过滤条件,在子查询中通可以使用 IN、EXISTS、ANY、ALL 操作符。

        使用 IN 关键字进行子查询时,内层查询语句仅返回一个数据列,这个数据列中的将供外层查询语句进行比较操作。

        例如,查询存在年龄为 20岁的员工的部门,SQL语句如下:

SELECT * FROM department WHERE did IN(SELECT did FROM employee WHERE age=20);

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

mysql> SELECT * FROM department WHERE did IN(SELECT did FROM employee WHERE age=20);
+-----+-----------+
| did | dname     |
+-----+-----------+
|   1 | 网络部    |
|   2 | 媒体部    |
+-----+-----------+
2 rows in set (0.04 sec)

        从上述结果可以看出,只有网络部和媒体部有年龄为20岁的员工。在查询的过中,首先会执行内层子查询,得到年龄为 20岁的员工的部门id,然后根据部门id与外查询的比较条件,最终得到符合条件的数据。
        SELECT 语句中还可以使用 NOT IN 关键字,其作用正好与 IN 相反。

        例如,查询不存在年龄为 20岁的员工的部门,SQL语句如下:

SELEcT * FROM department WHERE did NOT IN (SELECT did FROM employee WHERE age=20);

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

mysql> SELEcT * FROM department WHERE did NOT IN (SELECT did FROM employee WHERE age=20);
+-----+-----------+
| did | dname     |
+-----+-----------+
|   3 | 研发部    |
|   5 | 人事部    |
+-----+-----------+
2 rows in set (0.01 sec)

        从上述结果可以看出,只有研发部与人事部不存在年龄为 20岁的员工。明显可以看出,使用 NOT IN 关键字的査询结果与使用 IN 关键字的查询结果正好相反。
 


http://www.kler.cn/a/284923.html

相关文章:

  • [ 网络安全介绍 5 ] 为什么要学习网络安全?
  • WebRTC API分析
  • 2024 年 8 个最佳 API 设计工具图文介绍
  • Hadoop(环境搭建篇)
  • 【JAVA】正则表达式中的中括弧
  • 【juc】AbstractQueuedSynchronized为什么采用双向链表
  • Xilinx高速接口之GTP
  • CSS 预处理器
  • 10、ollama启动LLama_Factory微调大模型(llama.cpp)
  • opencv之形态学
  • 喜羊羊做Python真题
  • 基于Android+SQLite数据库开发Java考试App
  • 深度学习100问15:什么是交叉熵误差
  • 【Linux】Linux Bash Shell 教程
  • 工程师们都爱看的Docker容器技术,一看就会!保姆级教程(上)
  • Nginx负载均衡请求队列配置:优化流量管理
  • MySQL:简述事务的SQL操作
  • K8S Job
  • CSS优化实践
  • 计算机毕业设计选题推荐-二手物品回收系统-Java/Python项目实战
  • Nuxt3入门:资源文件(第2节)
  • LeetCode第65题 有效数字 结合设计模式:状态模式
  • Linux下C++编程使用动态链接库
  • Openldap可视化工具PhpLdapAdmin服务配置
  • TMPDIR在pip|pip3 install时的作用以及tmp只有noexec权限的解决方法
  • 问题记录之Qt Creator下qDebug中文乱码