数据库DML语句之子查询

子查询查询语句嵌套的查询语句就是子查询,子查询语句须要用圆括号括起来,结尾不能有分号。子查询返回的数据池可看成在内存中的一张临时表。断电关机后就消失,语句运行时才有数据。子查询得到的数据也称为数据池或者临时表

1、where子查询

1、单值子查询基本格式:

SELECT  <列名表>

FROM  表名

WHERE 字段 比较运算符 (SELECT 列名 FROM 表名WHERE 条件) ;

例:查找出与“SMITH”在同一个部门的所有职工姓名及工资

select ename,sal

from emp

where deptno=(SMITH所在的部门);

--SMITH所在的部门

select deptno from emp where ename='SMITH';

--将子查询带入外层查询

select ename,sal,deptno

from emp

where deptno=(select deptno from emp where ename='SMITH');

-----对于该子查询命令,系统执行时先执行子查询,返回一个值(即SMITH的部门号)作为主要查询(或外层查询)的条件,然后再根据该条件执行主查询选择出预期的结果,即与“SMITH”同一部门的所有职工。

2、

多值子查询基本格式:

SELECT  <列名表>

FROM  表名

WHERE 字段 in/not in (SELECT 列名 FROM 表名WHERE 条件) ;

例:查找出工资在2500到3500元之间的职工所在部门的所有人员的有关信息。
select *
from emp
where deptno in (工资在2500到3500元之间的职工所在部门);
--工资在2500到3500元之间的职工所在部门号
select distinct deptno from emp where sal between 2500 and 3500;
--将多行子查询带入外层查询
select *
from emp
where deptno in (select distinct deptno from emp where sal between 2500 and 3500);

总结:1.等于号右边有一个值的时候用等于号。

2.等于号右边有多个值或者一个值的时候用in或者用=any()。

2、 From子查询

1、From子查询基本格式:

SELECT  <列名表>

FROM  (SELECT 列名 FROM 表名WHERE 条件)

WHERE 条件;

例:查询工作是clerk的员工姓名和工作
select ename,job
from emp
where job='CLERK';
--上题的子查询做法
select e2.ename,e2.job
from (select * from emp where job='CLERK') e2;

3、where子查询和from子查询的区别

from子查询的查询效率比where子查询要高

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值