MySQL之多表查询—列子查询

news2024/11/24 16:00:22

一、引言

标量子查询上篇博客已学习。接下来这篇博客学习子查询的第二种形式——列子查询

  • 列子查询

子查询返回的结果是一列(当然也可以是多行),这种子查询称为列子查询。

  • 列子查询可以使用的操作符

IN、NOT IN 、ANY(any)、SOME 、 ALL

注意

1、复习前面条件查询,IN() ,只要满足括号中其一就行

2、 IN 和 NOT IN 就是在指定范围之内多选一 和 不在指定的范围之内

3、any 和 some 它们指定的意思是一样的。与 all 的区别就是前者任意一个满足就可以了,后者所有值都得满足

接下来通过三个案例来说明列子查询的具体操作和语法。

二、操作

打开 Data Grip 工具进行操作。

(0)员工表 emp 、部门表 dept

(1)查询 “ 销售部 ” 和 “ 市场部 ” 的所有员工信息

1、分析

先查销售部和市场部的部门id。然后再根据部门id查询员工信息

第一步:

SELECT id FROM dept WHERE name='销售部' OR name='市场部';

第二步:

SELECT * FROM emp WHERE dept_id IN(2,4);

结果:

2、把两句SQL查询语句结合起来

SELECT * FROM emp WHERE dept_id IN(SELECT id FROM dept WHERE name='销售部' OR name='市场部');

这样就可以了,因为括号里的子查询返回的值是一列多列,这种子查询称为列子查询。

(2)查询比财务部所有人工资都高的员工信息

1、分析

先查询出财务部所有员工的工资(一列多行),再去查询比财务部所有人工资都高的员工

SELECT id FROM dept WHERE name='财务部';
SELECT salary FROM emp WHERE dept_id=3;
SELECT * FROM emp WHERE salary >8500;

这样的SQL语句不行,不方便也比较慢。

2、三句SQL结合起来成一条SQL语句

第一句嵌套进第二句(标量子查询),第二个查询返回的结果放到第三个查询(列子查询)

SELECT * FROM emp WHERE salary > ALL (SELECT salary FROM emp WHERE dept_id = (SELECT id FROM dept WHERE name='财务部'));

ALL 代表查询出来的工资要大于 返回的所有财务部员工的工资。

(也就是比财务部最高工资的员工工资还要高)

(3)查询比研发部其中任意一人工资高的员工信息(比最小的就可以了)

1、分析

先查询研发部所有人的工资,再查询研发部中工资最低的员工工资,再比较查询员工信息

2、实操

SELECT * FROM emp WHERE salary > ANY (SELECT salary FROM emp WHERE dept_id=(SELECT id FROM dept WHERE name='研发部'));

或者

SELECT * FROM emp WHERE salary > SOME (SELECT salary FROM emp WHERE dept_id=(SELECT id FROM dept WHERE name='研发部'));

ANY:指里面任何一个就可以了。

这里 ANY (any) 也可以换成 SOME (some),效果是一样的。

这篇博客的内容就介绍了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1807100.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

windows域控共享网络驱动器

背景 假设在一家公司,有新入职的员工。我们给其创建了域账号,有一些共享的文件需要其可以直接访问到。我们可以采用共享目录的形式,但是每次都要输入共享端的ip或者主机名,比较麻烦。我们希望创建的域账号访问共享文件更便捷一些…

使用Flask框架在Python中获取HTTP请求头信息

目录 引言 一、Flask框架简介 二、获取HTTP请求头的方法 三、案例分析 案例一:基于请求头进行用户身份验证 案例二:基于请求头的内容类型处理不同格式的响应 四、总结 引言 在Web开发领域,HTTP协议是客户端和服务器之间进行通信的基础…

爆破信息壁垒!多少考研人还在盲目刷题?

有些同学,天生擅长冲锋陷阵,不擅长思考总结。 忌:看视频一日千里,看例题从不动笔。 —— 新知识都“会”,旧知识都不会。 大忌:做题没思路,一看答案都会! 24的学长学姐&#xff0c…

抽象的java入门1.3.2

前言: 全新版本的函数(方法)定义,更简单 1.优化了验证过程,直击本质 2.新增目前一图流 正片: 函数的结构可以分为三部分:函数名,参数,函数体 一生二,二生…

VS2019专业版 C#和MFC安装

1. VS2019专业版下载地址 https://learn.microsoft.com/en-us/visualstudio/releases/2019/history 2.安装 C# 部分 MFC部分

ATTCK红队评估(五)

环境搭建 靶场拓扑图: 靶机下载地址: 漏洞详情 外网信息收集 确定目标靶机地址: 发现主机192.168.135.150主机是本次攻击的目标地址。探测靶机开放的端口信息: 目标靶机开放了两个端口:80、3306,那没什么意外的话就是…

服务部署:.NET项目使用Docker构建镜像与部署

前提条件 安装Docker:确保你的Linux系统上已经安装了Docker。如果没有,请参考官方文档进行安装。 步骤一:准备项目文件 将你的.NET项目从Windows系统复制到Linux系统。你可以使用Git、SCP等工具来完成这个操作。如何是使用virtualbox虚拟电…

2024年6月8日 每周新增游戏

中医百科中药: 中医百科中药是一款非常强大的中药知识科普软件,该应用提供500多味中草药的文献资料,强大的搜索功能可根据功效、特点和关键词来快速查找中药,而且每味中药的图片、功效、主治、炮制方法等百科知识,可以很好的帮助你…

深入理解指针(三)

一、指针运算 1.1指针-整数 下面我们来看一个指针加整数的例子&#xff1a; #include<stdio.h> int main() { int arr[10] { 1,2,3,4,5,6,7,8,9,10 }; int* p &arr[0]; int i 0; int sz sizeof(arr) / sizeof(arr[0]); for (i 0; i < …

QT c++ 堆栈一些理解--限制对象建立在栈上--栈堆区别

图示形象化理解&#xff1a; 堆栈都是数据结构存取数据的方式 堆&#xff1a;理解为一个堆积物体&#xff0c;独立的分散的&#xff0c;当需要空间时&#xff0c;再找一个地方。需要的就是new关键字&#xff0c;动态申请一个空间。程序员自己动态分配空间&#xff0c;使用指针…

最近很多朋友都消失了。。。

你好&#xff0c;我是郭震 1 聊聊现状 最近听到一些铁铁们&#xff0c;跟我聊&#xff0c;聊到现在的工作情况。 有的工作几年被裁&#xff0c;现在待业找工作。 还有些学校毕业目前未找到工作。 还有一些从上海、北京离开回老家了。 关注我的很多都是IT相关或对编程学习感兴趣…

(南京观海微电子)——液晶画面Crosstalk的原理与本质分析

一、H-Crosstalk (与EE开发相关) 1.画面轻重载切换交界处有水平弱线或Block – Power IC 相关 – Root cause&#xff1a;AVDD drop 后恢复过慢 – Solution : Power IC 补偿调整优化 范例&#xff1a;AVDD在重载区Drop明显&#xff0c;且恢复较慢导致的Hcrosstalk&#xff1b;…

目录穿越漏洞CVE-2018-7171复现 又学到一招小技巧!!!!

还是半夜睡不着&#xff0c;打开靶机开始操作。今天看了文件下载和目录穿越漏洞想结合以及防御方法。半夜来进行操作一波。复现一下漏洞&#xff0c;这个网上的文章页比较的少&#xff01;&#xff01;&#xff01; 开始操作起来&#xff01;&#xff01;&#xff01; 进入到页…

Vue3中的常见组件通信之`$refs`、`$parent`

Vue3中的常见组件通信之$refs、$parent 概述 ​ 在vue3中常见的组件通信有props、mitt、v-model、 r e f s 、 refs、 refs、parent、provide、inject、pinia、slot等。不同的组件关系用不同的传递方式。常见的撘配形式如下表所示。 组件关系传递方式父传子1. props2. v-mod…

Linux “ 软件管理 “

软件管理 widows 安装 方法一&#xff1a; 双击exe安装包&#xff0c;就可以安装。 用exe安装的软件会破记录到注册表中。 注册会记录安装位置&#xff0c;软件名称。 方法二&#xff1a; 用绿色方式进行安装。 不用写到注册表中&#xff0c;因此无法在开始菜单里面查看和卸…

javascript二进制流转图片的操作方法:File、Blob、FileReader、ArrayBuffer、Base64格式之间的转换

文章目录 引言I 使用img标签来加载图片1.1 使用img标签来加载图片1.2 在加载图片时进行身份验证: sign/AuthorizationII 跨域请求中包含凭证2.1 Fetch API在跨域请求中包含凭证2.2 ajax在跨域请求中包含凭证III 显示图片方式3.1 创建一个URL指向这个Blob对象3.2 获取ArrayBuff…

用AI制作历史解说视频:GPT + MidJourney + PiKa + FunSound + 剪映

1. 项目介绍 最近某站看到一个看到利用AI创作视频解说&#xff0c;成品画面很酷炫。对此以初学者视角进行复现&#xff0c;创意来源&#xff1a;用AI制作历史解说视频 2. 开始创作 我们参照原作者展示的内容&#xff0c;对古代人物屈原来生成解说视频。 2.1 故事脚本分镜 【…

C++全栈聊天项目(20) 聊天列表动态加载

聊天列表动态加载 如果要动态加载聊天列表内容&#xff0c;我们可以在列表的滚动区域捕获鼠标滑轮事件&#xff0c;并且在滚动到底部的时候我们发送一个加载聊天用户的信号 bool ChatUserList::eventFilter(QObject *watched, QEvent *event) {// 检查事件是否是鼠标悬浮进入…

dockerhub不可用临时解决方案

近日&#xff0c;在拉取一些docker hub的镜像的时候死活拉不下来&#xff0c;要么超时&#xff0c;要么无法接站点地址&#xff0c;不管是docker hub,还是国内镜像站&#xff0c;统统都不行了。 经过各大媒体报道&#xff0c;以及自己的亲身验证&#xff0c;才知道&#xff0c…

[imx6ull]Linux下的SocketCAN通信

文章目录 一、CAN总线协议1.简介2.电气属性3.通信原理①数据帧的帧格式&#xff1a;②总线同步③总线竞争④数据保护 二、Linux下CAN的操作1.硬件连接①CAN电平转换器②扩展板使用CAN 2.查询 can 信息3.开启/关闭 can4.发送/接收 can 数据5.设置 can 参数 三、CAN的回环测试四、…