子查询

嵌套在其他语句内部的select语句称为子查询或内查询,外层的语句可以是insert、update、delete、select等,一般select作为外层语句较多。外面如果为select语句,则此语句称为外查询或主查询

【说明】:

  • 子查询 ( 内查询) 在主查询之前执行完成。
  • 子查询的结果被主查询( 外查询)使用 。
  • 多行子查询和单行子查询操作不能混用

分类

分类 说明
标量子查询(单行子查询) 结果集为一行一列
列子查询(多行子查询) 结果集为多行一列
行子查询 结果集为多行多列
表子查询 结果集为多行多列

使用

按出现位置

  • select后面:

    仅仅支持标量子查询(一行一列)

  • from后面:

    1. 表子查询(将子查询结果充当一张表),要求必须起别名
  • where或having后面:

    标量子查询

    列子查询

    行子查询

  • exists后面:

    标量子查询

    列子查询

    行子查询

    表子查询

注意:

  • 单行子查询操作符::= > >= < <= <>(不等)
  • 多行子查询操作符:IN/NOT IN ANY|SOME ALL
  • 能用exists的地方都能用in
  1. #查询有员工的部门名
  2. use myemployees
  3. SELECT department_id
  4. FROM departments d
  5. WHERE EXISTS(
  6. SELECT *
  7. FROM employees e
  8. WHERE d.department_id = e.department_id
  9. )
  10. #in写法
  11. SELECT department_id
  12. FROM departments
  13. WHERE department_id in (
  14. SELECT department_id
  15. FROM employees e
  16. )

综合案例

  1. #查询工资最低的员工信息
  2. #1、查询最低工资
  3. SELECT MIN(salary)
  4. FROM employees;
  5. #2、salary = 1
  6. SELECT last_name,salary
  7. FROM employees
  8. WHERE salary = (
  9. SELECT MIN(salary)
  10. FROM employees
  11. );
  12. #查询平均工资最低的部门信息
  13. #1、查询每个部门的平均工资
  14. SELECT AVG(salary),department_id
  15. FROM employees
  16. GROUP BY department_id
  17. #2、
  18. SELECT ag,d.*
  19. FROM departments d
  20. INNER JOIN (
  21. SELECT AVG(salary) ag,department_id
  22. FROM employees
  23. GROUP BY department_id
  24. ORDER BY ag
  25. LIMIT 1
  26. ) d_avg
  27. ON d_avg.department_id = d.department_id
  28. #查询平均工资最高的job信息
  29. #1、查询平均工资最高的job_id
  30. SELECT AVG(salary),job_id
  31. FROM employees
  32. GROUP BY job_id
  33. ORDER BY AVG(salary) DESC
  34. LIMIT 1
  35. #2、
  36. SELECT *
  37. FROM jobs
  38. WHERE job_id = (
  39. SELECT job_id
  40. FROM employees
  41. GROUP BY job_id
  42. ORDER BY AVG(salary) DESC
  43. LIMIT 1
  44. )

联合查询

常用于查询多个表,且多表之间没有直接的连接关系

  1. 查询语句1
  2. union
  3. 查询语句2
  4. union
  5. 查询语句3
  6. ...;

作用:

  • 可将一条比较复杂的查询语句拆分成多条语句
  • 可将无关联的表合并在一起,连接查询需要两表中有关联的属性联合查询不需要

注意:

  • union关键字会去重,想要保留重复数据,则要使用union all
  • 只在最后一个查询语句后加分号结束符;
  • 要求多条查询语句的查询列数必须一致
  • 要求多条查询语句的查询的各列类型、顺序一致,若不一致则按第一条的顺 序排列
  • union 会去重,union all包含重复项

子查询 & 联合查询的更多相关文章

  1. MySQL的查询,子查询,联结查询,联合查询

    MySQL的查询,子查询,联结查询,联合查询 一.mysql查询的五种子句where(条件查询).having(筛选).group by(分组).order by(排序).limit(限制结果数) 二 ...

  2. MySQL数据库8 -子查询,联合查询

    一 使用IN关键字的子查询 问题: 查询游戏类型是'棋牌类' 的游戏的分数信息 - 游戏分数表中并未包含游戏类型信息 思路一:采用链接查询 思路二: 分两步进行,首先找到所以'棋牌类'游戏的编号,再以 ...

  3. MySQL数据库 —子查询,联合查询

    一 使用IN关键字的子查询 1.查询游戏类型是'棋牌类' 的游戏的分数信息 游戏分数表中并未包含游戏类型信息 思路一:采用链接查询 思路二: 分两步进行,首先找到所以'棋牌类'游戏的编号,再以这一组编 ...

  4. 转:EntityFramework查询--联合查询(Join,GroupJoin)

    首先我们先看一下Join public static IEnumerable<TResult> Join<TOuter, TInner, TKey, TResult>(this ...

  5. EntityFramework查询--联合查询(Join,GroupJoin)

    首先我们先看一下Join public static IEnumerable<TResult> Join<TOuter, TInner, TKey, TResult>(this ...

  6. MySQL (六)--外键、联合查询、子查询

    1 外键 外键:foreign key,外面的键(键不在自己表中),如果一张表中有一个字段(非主键)指向另外一张表的主键,那么将该字段称为外键. 1.1 增加外键 外键可以在创建表的时候或创建表之后增 ...

  7. mysql之连接查询、联合查询、子查询

    本文内容: 连接查询 联合查询 子查询 from子查询 where子查询 exists子查询 首发日期:2018-04-11 连接查询: 连接查询就是将多个表联合起来查询,连接查询方式有内连接.外连接 ...

  8. Mysql连接查询、子查询、联合查询 整理

    连接查询 连接语法的基本形式 from 表1  [连接方式]  join 表2  [on 连接条件]: 交叉连接 语法: from  表1  [cross]  join  表2  ;      //可 ...

  9. mysql学习之路_联合查询与子查询

    联合查询 联合查询:将多次查询(多条select语句)在记录上进行拼接(字段不会增加). 语法:多条select语句构成,每条select语句获取的字段必须严格一致(但是字段类型无关). Select ...

随机推荐

  1. css3中的陌生词汇

    Transform transform属性是静态属性,一旦写到style里面,将会直接显示作用,无任何变化过程.transform的主要用途是用来做元素的特殊变形. 关于图形变形的基础条件当中的原点设 ...

  2. CF280D-k-Maximum Subsequence Sum【模拟费用流,线段树】

    正题 题目链接:https://www.luogu.com.cn/problem/CF280D 题目大意 一个长度为\(n\)的序列,\(m\)次操作 修改一个数 询问一个区间中选出\(k\)段不交子 ...

  3. Redis分布式锁,看完不懂你打我

    简易的redis分布式锁 加锁: set key my_random_value NX PX 30000 这个命令比setnx好,因为可以同时设置过期时间.不设置过期时间,应用挂了,解不了锁,就一直锁 ...

  4. vulnhub靶机-Me and My Girlfriend: 1

    vulnhub靶机实战 1.靶机地址:https://www.vulnhub.com/entry/me-and-my-girlfriend-1,409/ 2.先看描述(要求) 通过这个我们可以知道我们 ...

  5. FastAPI(62)- FastAPI 部署在 Docker

    Docker 学习 https://www.cnblogs.com/poloyy/p/15257059.html 项目结构 . ├── app │   ├── __init__.py │ └── ma ...

  6. CentOS 7.9+19c单实例静默安装

    一.环境准备 二.解压文件 三.文件配置 四.安装 五.相关调整 六.打补丁 一.环境准备0.依赖包安装 rpm -q --qf '%{NAME}-%{VERSION}-%{RELEASE} (%{A ...

  7. java程序远程连接Linux服务器

    JSCH或 Ganymed Ganymed: Ganymed SSH-2 for Java是用纯Java实现SSH-2协议的一个包. 可以利用它直接在Java程序中连接SSH服务器.官网地址为 htt ...

  8. PTA实验7-2-3 求矩阵的局部极大值 (15分)

    实验7-2-3 求矩阵的局部极大值 (15分) 给定M行N列的整数矩阵A,如果A的非边界元素A[i][j]大于相邻的上下左右4个元素,那么就称元素A[i][j]是矩阵的局部极大值.本题要求给定矩阵的全 ...

  9. Windows使用Git的vim编辑器编译运行程序

    Windows配置gcc 新建一个main.c $ touch main.c #在当前目录下创建main.c $ mkdir folder #在当前目录下创建folder文件夹 $ rm main.c ...

  10. Windows用cmd编译运行C程序

    在Windows环境下用命令行编译运行程序 浙江大学-C语言程序设计进阶 配置gcc 准备一个Dev-cpp 找到gcc.exe所在目录 Dev-Cpp\MinGW64\bin 地址栏右键将地址复制为 ...