MySQL实例讲解子查询的使用

目录
  • 子查询-嵌套查询
    • 原始查询方法
    • 自连接
    • 子查询
    • 子查询分类
    • 单行子查询
    • 子查询的编写思路
    • HAVING中的子查询
    • CASE中的子查询
    • 子查询中的空值问题
    • 多行子查询
    • 多行比较操作符
    • 相关子查询
  • EXISTS与NOT EXISTS 关键字

子查询-嵌套查询

子查询是指一个查询语句嵌套在另一个语句内部的查询

原始查询方法

SELECT last_name,salaryFROM employeesWHERE last_name='Abel';SELECT last_name,salaryFROM employeesWHERE salary>11000;

自连接

SELECT e2.last_name,e2.salaryFROM employees e1,employees e2WHERE e2.salary>e1.salary AND e1.last_name='Abel';

子查询

SELECT last_name,salaryFROM employeesWHERE salary>(SELECT salaryFROM employeesWHERE last_name='Abel');

称谓的规范:外查询(或主查询),内查询

  • 子查询(内查询)在主查询之前一次执行完成。
  • 子查询的结果被主查询(外查询)使用 。

注意事项

  • 子查询要包含在括号内
  • 将子查询放在比较条件的右侧
  • 单行操作符对应单行子查询,多行操作符对应多行子查询

子查询分类

单行子查询 vs 多行子查询

  • 按内查询的结果返回一条还是多条记录,将子查询分为单行子查询和多行子查询

相关子查询vs不相关子查询

  • 按照内查询是否被执行多次进行划分
  • 相关子查询需求:查询工资大于本部分平均工资的员工信息
  • 不相关子查询需求:查询工资大于本公司平均工资的员工信息

单行子查询

单行比较运算符

操作符 含义
= equal to
> greater than
>= greater than or equal to
< less than
<= less than or equal to
<> not equal to

子查询的编写思路

  • 从里往外写
  • 从外往里写
SELECT *
FROM employees
WHERE salary>(
		SELECT salary
		FROM employees
		WHERE employee_id=149
);
SELECT last_name,job_id,salary
FROM employees
WHERE job_id=(
		SELECT job_id
		FROM employees
		WHERE employee_id=141
)
AND
salary >(
	SELECT salary
	FROM employees
	WHERE employee_id=143
);
SELECT employee_id,manager_id,department_id
FROM employees
WHERE manager_id=(
									SELECT manager_id
									FROM employees
									WHERE employee_id=141
)
AND
department_id=(
									SELECT department_id
									FROM employees
									WHERE employee_id=141
)
AND
employee_id<>141;
SELECT employee_id,manager_id,department_id
FROM employees
WHERE (manager_id,department_id)=(
									SELECT manager_id,department_id
									FROM employees
									WHERE employee_id=141
)
AND
employee_id<>141;

HAVING中的子查询

  • 先执行子查询
  • 向主查询中的HAVING字句返回结果
SELECT department_id,MIN(salary)
FROM employees
GROUP BY department_id
HAVING MIN(salary)>(
						SELECT MIN(salary)
						FROM employees
						WHERE department_id=50
);

CASE中的子查询

在CASE表达式中使用单列子查询

SELECT employee_id,last_name ,CASE department_id WHEN (SELECT department_id FROM departments WHERE location_id=1800) THEN 'Canada'																								ELSE 'USA' END 'location'
FROM employees;

子查询中的空值问题

若内查询查询结果为空的,则不会报错,子查询不会返回任何行

非法使用子查询

多行子查询

多行子查询也被称为集合比较子查询

内查询返回多行数据

使用多行比较操作符

多行比较操作符

操作符 含义
IN 等于列表中的任意一个
ANY 需要和单行比较操作符一起使用,和子查询返回的某一个值比较(任一)
ALL 需要和单行比较操作符一起使用,和子查询返回的所有值比较
SOME 实际上是ANY的别名,作用相同,一般常使用ANY

MySQL中聚合函数是不能嵌套的

SELECT employee_id,last_name
FROM employees
WHERE salary IN
(
	SELECT MIN(salary)
	FROM employees
	GROUP BY department_id
);
SELECT employee_id,last_name,job_id,salary
FROM employees
WHERE job_id<>'IT_PROG'
AND salary < ANY (
	SELECT salary
	FROM employees
	WHERE job_id='IT_PROG'
);
SELECT employee_id,last_name,job_id,salary
FROM employees
WHERE job_id<>'IT_PROG'
AND salary < ALL (
	SELECT salary
	FROM employees
	WHERE job_id='IT_PROG'
);
SELECT department_id
FROM employees
GROUP BY department_id
HAVING AVG(salary) <= ALL (
	SELECT AVG(salary) avgsal
	FROM employees
	GROUP BY department_id
);
SELECT department_id
FROM employees
GROUP BY department_id
HAVING AVG(salary)=
(
SELECT MIN(avgsal)
FROM (
SELECT AVG(salary) avgsal
FROM employees
GROUP BY department_id
) dbsal
);

多行子查询空值问题

子查询中存在空值的情况将使得查询结果生成的位空

相关子查询

如果子查询的执行依赖于外部查询,通常情况下是因为子查询中的表用到了外部的表,并进行了条件关联,因此每职系那个一次外部查询,子查询都需要重新计算一次,这样的子查询便被称之为关联子查询

相关子查询按照一行接一行的顺序执行,主查询的每一行都执行一次子查询

  • GET 从主查询中获取候选列
  • EXECUTE 子查询使用主查询的数据
  • USE 如果满足子查询的条件则返回该行
  • 再返回1
SELECT last_name,salary,department_id
FROM employees e1
WHERE salary > (
	SELECT AVG(salary)
	FROM employees e2
	WHERE department_id=e1.department_id
);
#在from中进行子查询
SELECT e1.last_name,e1.salary,e1.department_id
FROM employees e1,
(
SELECT department_id ,AVG(salary) avgs
FROM employees
GROUP BY department_id
) t1
WHERE e1.department_id=t1.depa
SELECT employee_id,salary
FROM employees e
ORDER BY(
	SELECT department_name
	FROM departments d
	WHERE e.department_id=d.department_id
) ASC;
SELECT employee_id,last_name,job_id
FROM employees e
WHERE 2<= (
	SELECT COUNT(*)
	FROM job_history j
	WHERE e.employee_id=j.employee_id
)

结论:在SELECT中,除了GROUP BY和LIMIT之外,其他位置都可以声明子查询

EXISTS与NOT EXISTS 关键字

关联子查询通常也会和EXISTS操作符一起来使用,用来检查在子查询中是否存在满足条件的行

如果在子查询中不存在满足条件的行

  • 条件返回FALSE
  • 继续在子查询中查找

如果在子查询中存在满足条件的行

  • 不在子查询中继续查找
  • 条件返回TRUE

NOT EXISTS关键字表示不存在某种条件,则返回TRUE,否则返回FALSE

到此这篇关于MySQL实例讲解子查询的使用的文章就介绍到这了,更多相关MySQL子查询内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • MySQL数据库子查询 sub query

    目录 1.基本概念 1.1.子查询 1.2.主查询 1.3.子查询和主查询的关系 1.4.子查询的分类 2.标量子查询 2.1.基本语法 2.2.示例 3.列子查询 3.1.基本语法 3.2.示例 4.行子查询 4.1.基本语法 4.2.示例 5.表子查询 5.1.基本语法 5.2.示例 6.exists子查询 6.1.基本语法 6.2.示例 7.子查询中的特定关键字 7.1.in 7.2.any 7.3.some 7.4.all 7.5.值为null 1.基本概念 1.1.子查询 嵌套查询下层

  • MySql数据库基础之子查询详解

    目录 1. 什么是子查询 2. 子查询可以出现在哪里 3. where子句的子查询 4. from子句的子查询 5. select后面出现的子查询 1. 什么是子查询 select 语句中嵌套 select 语句,被嵌套的 select 语句称为子查询. 2. 子查询可以出现在哪里 select    ...(select)from    ...(select)where    ...(select) 3. where子句的子查询 找出比最低工资高的员工姓名和工资? 第一步查询最低工资是多少 s

  • MySQL子查询原理的深入分析

    目录 01前言 02准备内容 03子查询的语法形式和分类 3.1 语法形式 3.1.1  FROM子句中 3.1.2 WHERE或IN子句中 3.2 分类 3.2.1 按返回的结果集区分 3.2.2 按与外层查询关系来区分 04子查询在MySQL中是怎么执行的 4.1 标量子查询.行子查询的执行方式 4.1.1 不相关子查询 4.1.2 相关的子查询 4.2 IN子查询 4.2.1 物化 4.2.2 半联接的实现: 4.2.3 半联接的适用条件 4.2.4 转为 EXISTS 子查询 05总结

  • MySQL子查询详细教程

    目录 1.where后面嵌套子查询 2.from后面嵌套子查询* 3.在select 后面嵌套子查询 4.union 5.*limit 定义:select语句中嵌套select语句,被嵌套的select语句是子查询. 子查询可以出现在: select ....(select).. from ....(select).. where ....(select).. 1.where后面嵌套子查询 select * from emp where sal > (select avg(sal) from e

  • MySQL数据库子查询语法规则详解

    目录 子查询简介 WHERE 子查询 FROM 子查询 SELECT 子查询 子查询是在查询语句里面再嵌套一个查询,这是因为我们在提取数据的时候有很多不知道的数据产生了依赖关系.此时我们就需要先查询一组数据的结果集,然后将这个结果集作用为下一个查询的对象.在 “表连接的章节”,我们曾说过子查询的效率低下的问题,其实并不是所有的子查询效率都是低下的,“WHERE” 子查询在匹配记录的时候要反复执行,这是不推荐使用的:但是如果将查询结果集当做一张表来使用,与其他的表做一个连接,这就是 “FROM”

  • Mysql子查询关键字的使用方式(exists)

    目录 1. all 1.1 格式 1.2 特点 1.3 操作 2. any(some) 1.1 格式 1.2 特点 1.3 操作 3. in 1.1 格式 1.2 特点 1.3 操作 4. exist 1.1 格式 1.2 特点 1.3 操作 1.4 解释 1. all 1.1 格式 1.2 特点 all:与子查询返回的所有值比较为true则返回true all可以与=,>=,>,<,<=,<>结合使用,分别表示等于,大于等于,大于,小于,小于等于,不等于其中的所有数据

  • MySQL实例讲解子查询的使用

    目录 子查询-嵌套查询 原始查询方法 自连接 子查询 子查询分类 单行子查询 子查询的编写思路 HAVING中的子查询 CASE中的子查询 子查询中的空值问题 多行子查询 多行比较操作符 相关子查询 EXISTS与NOT EXISTS 关键字 子查询-嵌套查询 子查询是指一个查询语句嵌套在另一个语句内部的查询 原始查询方法 SELECT last_name,salaryFROM employeesWHERE last_name='Abel';SELECT last_name,salaryFROM

  • mysql详细分析讲解子查询的使用

    出现在其他语句中的 select 语句,称为子查询或内查询:外部的查询语句,称为主查询或 外查询 . -- 子查询 -- 查询的条件来自于另一查询的结果 SELECT * FROM t_user WHERE number=(SELECT number FROM t_user WHERE NAME='张三') 当然子查询也有类型,分为以下几种 : 标量子查询(结果集只有一行一列) 列子查询(结果集只有一列多行) 行子查询(结果集有一行多列)(较少) 表子查询(结果集一般为多行多列) 这里我们以新建

  • 解决MySQL中IN子查询会导致无法使用索引问题

    今天看到一篇关于MySQL的IN子查询优化的案例, 一开始感觉有点半信半疑(如果是换做在SQL Server中,这种情况是绝对不可能的,后面会做一个简单的测试.) 随后动手按照他说的做了一个表来测试验证,发现MySQL的IN子查询做的不好,确实会导致无法使用索引的情况(IN子查询无法使用所以,场景是MySQL,截止的版本是5.7.18) MySQL的测试环境 测试表如下 create table test_table2 ( id int auto_increment primary key, p

  • MySQL里面的子查询的基本使用

    目录 一.子查询定义 二.子查询分类 1. 标量子查询: 2. MySQL 列子查询: 3. MySQL 行子查询: 4. MySQL 表子查询: 三.字查询例举 1. ANY进行子查询 2. 使用IN进行子查询 3. 使用SOME进行子查询 4. 使用ALL进行子查询 5.标量子查询 6. 多值子查询 7. 独立子查询 8.相关子查询 9.EXISTS谓词 10. 派生表 四.子查询优化 一.子查询定义 定义: 子查询允许把一个查询嵌套在另一个查询当中. 子查询,又叫内部查询,相对于内部查询,

  • 解决Mysql多行子查询的使用及空值问题

    目录 1 定义 2 多行比较操作符 3 空值问题 3.1 问题 3.2 解决 1 定义 也称为集合比较子查询 内查询返回多行 使用多行比较操作符 2 多行比较操作符 -- 多行子查询 -- IN SELECT employee_id, manager_id, department_id FROM employees WHERE manager_id IN ( -- 在返回集合中查找有没有相同的manager_id在里面 SELECT manager_id FROM employees WHERE

  • MySQL查询优化:用子查询代替非主键连接查询实例介绍

    一对多的两张表,一般是一张表的外键关联到另一个表的主键.但也有不一般的情况,也就是两个表并非通过其中一个表的主键关联. 例如: 复制代码 代码如下: create table t_team ( tid int primary key, tname varchar(100) ); create table t_people ( pid int primary key, pname varchar(100), team_name varchar(100) ); team表和people表是一对多的关

  • 详细讲述MySQL中的子查询操作

    继续做以下的前期准备工作: 新建一个测试数据库TestDB: create database TestDB; 创建测试表table1和table2: CREATE TABLE table1 ( customer_id VARCHAR(10) NOT NULL, city VARCHAR(10) NOT NULL, PRIMARY KEY(customer_id) )ENGINE=INNODB DEFAULT CHARSET=UTF8; CREATE TABLE table2 ( order_id

  • MySQL笔记之子查询使用介绍

    子查询是将一个查询语句嵌套在另一个查询语句中 内层查询语句的查询结果,可以为外层查询语句提供查询条件 因为在特定情况下,一个查询语句的条件需要另一个查询语句来获取 参考表:employee 参考表:department 带IN关键字的子查询 复制代码 代码如下: mysql> SELECT * FROM employee    -> WHERE d_id IN    -> (SELECT d_id FROM department);+------+------+--------+----

  • 在MySQL中使用子查询和标量子查询的基本操作教程

    MySQL 子查询 子查询是将一个 SELECT 语句的查询结果作为中间结果,供另一个 SQL 语句调用.MySQL 支持 SQL 标准要求的所有子查询格式和操作,也扩展了特有的几种特性. 子查询没有固定的语法,一个子查询的例子如下: SELECT * FROM article WHERE uid IN(SELECT uid FROM user WHERE status=1) 对应的两个数据表如下: article 文章表: user 用户表: 查询返回结果如下所示: 在该例子中,首先通过子查询

  • MySQL里面的子查询实例

    一,子选择基本用法 1,子选择的定义 子迭择允许把一个查询嵌套在另一个查询当中.比如说:一个考试记分项目把考试事件分为考试(T)和测验(Q)两种情形.下面这个查询就能只找出学生们的考试成绩 select * from score where event_id in (select event_id from event where type='T'); 2,子选择的用法(3种)         用子选择来生成一个参考值 在这种情况下,用内层的查询语句来检索出一个数据值,然后把这个数据值用在外层

随机推荐