数据操作语言:子查询

本文详细介绍了数据操作语言中的子查询,包括子查询的种类、使用位置及其效率分析。重点讨论了WHERE子查询、FROM子查询和SELECT子查询,强调了FROM子查询的高效性,并探讨了单行与多行子查询的应用。同时,文章还讲解了如何使用EXISTS关键字进行条件判断,以提高查询性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

子查询简介

  • 子查询是一种查询中嵌套 查询的语句
  • 查询底薪超过公司平均底薪的员工的信息
SELECT
	empno, ename, sal
FROM t_emp
WHERE sal>=(SELECT AVG(sal) FROM t_emp);
  • WHERE 语句的子查询不推荐使用,影响查询效率

子查询的分类

  • 子查询可以写在三个地方: WHERE子句、FROM子句、SELECT子句,但是只有FROM子句子查询是最可取的

WHERE子查询

  • 这种子查询最简单,最容易理解,但是却是效率很低的子查询,属于相关子查询
  • 查询底薪超过公司平均底薪的员工的信息
    在这里插入图片描述

FROM子查询

  • 这种子查询只会执行一次,所以查询效率很高
SELECT
	e.empno, e.ename, e.sal, t.avg
FROM t_emp e JOIN
(SELECT deptno, AVG (sal) as avg
FROM t_emp GROUP BY deptno) t
ON e.deptno=t.deptno AND e.sal>=t.avg;

SELECT子查询

  • 这种子查询每输出一条记录的时候都要执行一 次,查询效率很低,也属于相关子查询
  • 折冲子查询也不推荐使用
SELECT
	e.empno,
	e.ename,
	(SELECT dname FROM t_dept WHERE deptno=e.deptno)
FROM t_emp e;

单行子查询和多行子查询

  • 单行子查询的结果集只有一条记录,多行子查询结果集有多行记录
  • 多行子查询只能出现在WHERE子句和FROM子句中
  • 如何用子查询查找FORD和MARTIN两个人的同事?

使用where子查询

select ename
from t_emp
where deptno in
(select deptno from t_emp where ename in("FORD","MARTIN"))
and ename not in("FORD","MARTIN");

使用FROM 子查询

select e.ename
from t_emp e join 
(select deptno from t_emp where ename in('FORD',"MARTIN")) t
on e.deptno=t.deptno where e.ename not in("FORD","MARTIN");

在这里插入图片描述

WHERE子句中的多行子查询

  • WHERE子句中,可以使用IN、ALL、 ANY、 EXISTS关键字来处理多
    行表达式结果集的条件判断
  • 查询比FORD和MARTIN底薪都高的员工信息?
SELECT ename FROM t_emp 
WHERE sal > ALL
(SELECT sal FROM t_emp
WHERE ename IN("FORD" , "MARTIN"));

EXISTS关键字

  • EXISTS关键字是把原来在子查询之外的条件判断,写到了子查询的里面。
    SELECT ... FROM 表名 WHERE [NOT] EXISTS (子查询);
  • 查询工资等级是3级或者4级的员工信息?
select empno,ename,sal
from t_emp
where exists(
select * from t_salgrade
where sal between losal and hisal
and grade in(3,4));
  • 使用FROM子查询
select e.ename,e.empno,e.sal
from t_emp e join
(select losal,hisal from t_salgrade where grade in(3,4)) s
on e.sal between s.losal and s.hisal;

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值