当前位置: 首页 > 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/news/284923.html

相关文章:

  • 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中文乱码
  • SparkSQL缓存的用法
  • IM社交-前言
  • 负载均衡的分类有哪些?
  • 路由策略工具
  • 51单片机——模块化编程
  • Kafka分布式集群部署实战:跨越理论,直击生产环境部署难题与解决方案,性能调优、监控与管理策略大揭秘,轻松上手分布式消息中间件
  • 【SQL基础】【leetcode】SQL50题
  • 『功能项目』技能释放【08】
  • Java设计模式【解释器模式】-行为型
  • 【QT线程学习】