Mysql子查询

概念分析:

根据相关性分:

  (1)不相关子查询:一条Sql语句中含有多条SELECT语句,先执行子查询,再执行外查询,子查询可对立运行

          关键字:(1)先子查询,再外查询

              (2)可以对立运行,即可以单独运行子查询,对外查询不干扰

  (2)相关子查询:子查询不能独立运行,并且先运行外查询,再运行子查询

          关键字:(1)先外查询,再子查询

              (2)子查询不能独立运行

例如:

(1)不相关子查询

  1. --查询【和CLARK同一部门且比他工资低的】雇员名字和工资。
    -- 第一步:先查询CLARK部门和和CLARK工资
  1. select deptno from emp where ename='CLARK'
  1. select sal from emp where ename ='CLARK'
    -- 第三步:分别查询,部门和CLARK一样的,工资比他少的
  1. select ename ,sal,deptno from emp
  2. where deptno = (select deptno from emp where ename='CLARK')
  3. and sal < (select sal from emp where ename ='CLARK')
    这上面查询过程中:子查询可以独立运行,并且是先于外查询的,

(2)相关子查询

--查询[工资高于其所在部门20的平均工资的]那些员工
  select * from emp e1 where e1.deptno = 20 and sal >(select avg(sal) from emp e2 where e2.deptno = 10)

在这条语句中,子查询内部的WHERE关键字后的条件中外查询的条件参与,不能单独运行

二:根据查询结果

    (1)单行子查询:子查询结果只有一条数据

    (2)多行子查询:子查询结果有多条记录,此时之间不能用= < >,要借助 ANY  ALL IN 来实现

例如:

(1)单行子查询:

  1. --查得所有【比“CLARK”工资高的】员工的信息
  2. select * from emp
  3. select sal from emp where ename ='CLARK' --
  4. select * from emp where sal > 2450.00
  5. 子查询结果只有一条
  6. select * from emp where sal > (select sal from emp where ename ='CLARK')

(2)多行子查询

  1. --查询工资低于任何一个“CLERK”的工资的雇员信息。
  2. select * from emp where sal< (select max(sal) from emp where job ='CLERK')
  3. select sal from emp where job ='CLERK' --1300 1100 950 800
  4.  
  5. select * from emp where sal< any(select sal from emp where job ='CLERK')
  6.  
  7. --查询[工资比所有的“SALESMAN”都高的]雇员的编号、名字和工资。
  8. --ALL >ALL
  9. select empno,ename,sal from emp where sal >(select max(sal) from emp where job ='SALESMAN')
  10.  
  11. select empno,ename,sal from emp where sal > ALL(select sal from emp where job ='SALESMAN')
  12.  
  13. select max(sal) from emp where job ='SALESMAN'
  14.  
  15. --查询部门20中职务同部门10的雇员一样的雇员信息。
  16. select job from emp where deptno = 20 --CLERK ANALYST
  17. select job from emp where deptno = 10 --MANAGER PRESIDENT CLERK ---- CLERK MANAGER
  18. -- IN 等于其中任何一个
  19. select * from emp where deptno = 20 and job in (select job from emp where deptno = 10)

Mysql的子查询相关知识,少但是精的更多相关文章

  1. 聊聊MySQL的子查询

    1. 背景 在之前介绍MySQL执行计划的博文中已经谈及了一些关于子查询相关的执行计划与优化.本文将重点介绍MySQL中与子查询相关的内容,设计子查询优化策略,包含半连接子查询的优化与非半连接子查询的 ...

  2. mysql in 子查询 效率慢 优化(转)

    mysql in 子查询 效率慢 优化(转) 现在的CMS系统.博客系统.BBS等都喜欢使用标签tag作交叉链接,因此我也尝鲜用了下.但用了后发现我想查询某个tag的文章列表时速度很慢,达到5秒之久! ...

  3. MySQL 行子查询(转)

    MySQL 行子查询 行子查询是指子查询返回的结果集是一行 N 列,该子查询的结果通常是对表的某行数据进行查询而返回的结果集. 一个行子查询的例子如下: SELECT * FROM table1 WH ...

  4. MySQL FROM 子查询

    FROM 子句中的子查询 MySQL FROM 子查询是指 FROM 的子句作为子查询语句,主查询再到子查询结果中获取需要的数据.FROM 子查询语法如下: SELECT ... FROM (subq ...

  5. MySQL 表子查询

    MySQL 表子查询 表子查询是指子查询返回的结果集是 N 行 N 列的一个表数据. MySQL 表子查询实例 下面是用于例子的两张原始数据表: article 表: aid title conten ...

  6. MySQL 行子查询

    MySQL 行子查询 行子查询是指子查询返回的结果集是一行 N 列,该子查询的结果通常是对表的某行数据进行查询而返回的结果集. 一个行子查询的例子如下: SELECT * FROM table1 WH ...

  7. Mysql in子查询中加limit报错

    Mysql in子查询中加limit报错 select id from aa where id in ( select id from bb limit 10 ); 改写成 SELECT id FRO ...

  8. Mysql常用sql语句(20)- 子查询重点知识

    测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 子查询语句可以嵌套在 sql 语句中任何表达式出现的位 ...

  9. MySQL(五) —— 子查询

    子查询(SubQuery)是指出现在其他SQL语句内的SELECT语句. 如: SELECT * FROM t1 WHERE col1 = (SELECT col2 FROM t2); 其中 SELE ...

随机推荐

  1. c提高第六次课 文件读取

    一.基本概念1.文件分类 普通文件:存放在硬盘中的文件 设备文件:屏幕.键盘等特殊文件 文本文件:ASCII文件,每个字节存放一个字符的ASCII码,打开文件看到的是文本信息 二进制文件:数据按其在内 ...

  2. bugku crypto easy-crypto

    长度不一的01字符串 就要考虑是不是摩斯密码 用这个py脚本: from __future__ import print_function a = input("input the stri ...

  3. HDU1166-ZKW树

    单点修改,区间求和 // // Created by helica on 2018/3/18. // //zkw #include <cstdio> #include <cstrin ...

  4. 多线程threading

    threading用于提供线程相关的操作,线程是应用程序中工作的最小单元.python当前版本的多线程库没有实现优先级.线程组,线程也不能被停止.暂停.恢复.中断. 1.     threading模 ...

  5. 最简单的JAVA解析XML字符串方法

    引入 dom4j 包<dependency> <groupId>dom4j</groupId> <artifactId>dom4j</artifa ...

  6. 商誉专题RN及H5项目总结

    React(基础框架): React 是基础框架,是一套基础设计实现理念,开发者不能直接使用它来开发移动应用或者网页. React.js(web网页开发):在React框架之上,发展出了React.j ...

  7. Django学习目录

    Django学习目录 Django框架简介 Django基础 >>点我 ORM介绍 Django中ORM介绍 >>点我 ORM表操作 Django中ORM表相关操作 >& ...

  8. Docker 介绍及基础命令

    Docker 简介 Docker 是一个开源项目,诞生于 2013 年初,最初是 dotCloud 公司内部的一个业余项目.它基于 Google 公司推出的 Go 语言实现. 项目后来加入了 Linu ...

  9. winform项目导入数据

    一.点击导入按钮,弹出文件选择框 这个方法的使用要引用下面两个命名空间: using System.Windows.Forms;using DevExpress.XtraEditors; privat ...

  10. 编写高质量的Python代码系列(六)之内置模块

    Python预装了许多写程序时会用到的重要模块.这些标准软件包与通常意义上的Python语言联系得非常精密,我们可以将其当成语言规范的一部分.本节将会讲解基本的内置模块. 第四十二条:用functoo ...