Oracle入门笔记【2】子查询

1,wherer:子查询一般会返回单行单列 单行多列 多行单列 ;

2,having:子查询会返回单行单列,同时表示要使用统计函数;

3,from:子查询返回多行多列数据(表结构);

4,select:返回单行单列 (一般不使用);

where(进行数据行的筛选操作):

  • a:查询出低于公司平均工资的雇员信息。
select * from emp where sal<(select avg(sal) from emp);

以上的查询返回单行单列可以作为where子句的过滤条件使用;

  • b:查询公司最早雇佣的雇员的信息。
select * from emp where hiredate= (select MIN(hiredate) from emp);
  • C:查询与scott从事同一工作并且工资相同的雇员信息。
select* from emp
where (job,sal) =( select job,sal
 from emp
 where ename ='scott') and ename <>'scott';

in:指的是与子查询返回的内容相同。

select * from emp where sal in (select sal from emp where job = 'manager');

not in:

 select* from emp where sal not in(select sal from emp where job='manager')

子查询中不能有空。

any:
 select* from emp where sal = any(select sal from emp where job='manager');
  select* from emp where sal > any(select sal from emp where job='manager');

比子查询的返回的最大值要大

select* from emp where sal < any(select sal from emp where job='manager');

比子查询返回的最大值要小

all:

<all :比子查询的返回的最小值要小
>all :比子查询的返回的最大值要大
 where子查询的几率很高;

having:

  • 查询出高于公司平均工资的职位名称 职位人数 平均工资。
select job,count(empno),avg(sal) from emp group by job 
  having avg(sal)>(select avg(sal) from emp);

select(一般不用):

查询每个雇员的编号姓名 职位 部门名称。

select e.empno,e.ename,e.job,
(select d.dname from dept d whered.deptno=e.deptno)from emp e;

(1+n) 次查询;

from(重点):

  • 查询出每个部门的名称 位置 部门人数。
select d.dname,d.loc,count(e.empno)
from emp e,dept d
where e.deptno(+)=d.deptno
group by d.dname,d.loc;

(多表查询)

分步1:select d.deptno,d.dname,d.locfrom dept d;

分步2:select deptno,count(empno)from emp group by deptno;

正确的查询:

select d.deptno,d.dname,d.loc,temp.count 
   from dept d,(select deptno,count(empno) count from emp
   group by deptno) temp 
   where d.deptno=temp.deptno(+);
  • 多表查询和子查询都能实现统计,那么那种方式更好呢?

答:在实际的工作当中,子查询的主要目地是解决多表查询的性能问题,所以在开发中使用的是 最多的。最大作用是解决多表查询带来的笛卡尔积影响性能的问题。

复杂查询= 简单查询+限定查询+ 多表查询+ 分组统计查询 +子查询;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 查询是数据的一个重要操作。用户发送查询请求,经编译软件变异成二进制文件供服务器查询,后返回查询结果集给用户,查询会...
    产品小正阅读 1,459评论 0 2
  • 1.简介 数据存储有哪些方式?电子表格,纸质文件,数据库。 那么究竟什么是关系型数据库? 目前对数据库的分类主要是...
    乔震阅读 1,834评论 0 2
  • 幕课oracle学习笔记 --!!!scott用户 --一.分组查询 --1.常用的分组函数:AVG(平均数),S...
    xiaoxiao苏阅读 1,300评论 0 5
  • 5.多表查询 多表查询 目的:从多张表获取数据 前提:进行连接的多张表中有共同的列 等连接 通过两个表具有相同意义...
    乔震阅读 1,328评论 0 0
  • 1. select * from emp; 2. select empno, ename, job from em...
    海纳百川_4d26阅读 1,951评论 0 4