一道Oracle子查询小练习】的更多相关文章

一道Oracle子查询小练习   昨天晚上躺在床上看Oracle(最近在学习这个),室友说出个题目让我试试.题目如下: 有如下表结构,请选择出成绩为前三名的人的信息(如果成绩相同,则算并列),表名为test: NAME                      GRADE -------------------- ---------- kate                            80 jenny                          80 daring      …
本节介绍Oracle子查询的相关内容: 实例用到的数据为oracle中scott用户下的emp员工表,dept部门表,数据如下: 一.子查询 1.概念:嵌入在一个查询中的另一个查询语句,也就是说一个查询作为另一个查询的条件,这个查询称为子查询. 那么可以使用子查询的位置有select后面.from后面.where后面以及having后面. 2.分类:(1)单行子查询:查询结果只返回一行数据   (2)多行子查询:查询结果返回多行数据,多行子查询的操作符有IN,ALL,ANY,具体用法实例中说明.…
oracle 子查询和组合函数 --查询与"SCOTT"在同一个部门的员工 select empno,ename,deptno from emp where deptno in (select deptno from emp where ename='SCOTT'); --查找不在销售部和财务部工作的雇员编号.姓名和部门编号. select empno,ename,deptno from emp where deptno not in (select deptno from dept…
1.子查询在SELECT.UPDATE.DELETE语句内部可以出现SELECT语句.内部的SELECT语句结果可以作为外部语句中条件子句的一部分,也可以作为外部查询的临时表.子查询的类型有: ① 单行子查询:不向外部返回结果,或者只返回一行结果. ② 多行子查询:向外部返回零行.一行或者多行结果. 2.ANY 和 ALL ①<any:比子查询结果中任意的值都小,也就是说,比子查询结果中最大值还小,那么同理>any表示比子查询结果中最小的还大. SELECT ENAME,JOB,SAL FRO…
近来学习oracle,想要提高自己所写语句的效率和易读性,今天的笔记是关于子查询因子话这么一个东西 因子化的查询不一定可以提高效率,但是一定可以再提高程序的可读性方面成效显著 --with 语句 with sales_c ( select sales,e_NO,e_name from emplyee ) select * from sales_c; --查询的结果就是( select sales,e_NO,e_name from emplyee)这张字表中的内容 --with一次声明,在下面的例…
子查询:在一个查询的内部包含另外一个查询. 普通子查询 -- 查询出比7654工资还高的所有雇员的信息 select * from emp e where e.sal > (select sal from emp where empno = 7654); -- 查询出工资比7654高,同一时候与7788从事同样工作的所有雇员的信息 select * from emp e where e.sal > (select sal from emp where empno = 7654) and e.j…
where 子查询主要功能是控制数据行的,返回结果一般都是单行单列.多行单列.单行多列数据 单行单列 SELECT * FROM emp WHERE hiredate=( SELECT MIN(hiredate) FROM emp) ; 多行单列 (使用不多) SELECT * FROM emp WHERE (sal,job)=( SELECT sal,job FROM emp WHERE ename='SCOTT') AND ename<>'SCOTT' ; 多行单列 使用三个判断符号:IN…
Oracle 高级子查询 高级子查询相对于简单子查询来说,返回的数据行不再是一列,而是多列数据. 1,多列子查询 主查询与子查询返回的多个列进行比较 查询与141号或174号员工的manager_id和department_id相同的其他员工的employee_id, manager_id, department_id select employee_id, manager_id, department_id from employees where (manager_id,department…
Oracle 简单子查询 顾名思义,简单子查询是嵌套在 SQL 语句中的另一个SELECT 语句,并且子查询只返回一列数据 1,单行子查询: 子查询 (内查询) 在主查询之前一次执行完成.子查询的结果被主查询(外查询)使用 ,单行子查询,一个子查询语句只返回一行结果,不能返回空值 可以使用>,<,<>(!=),=,<=,>= select select_list from table where expr operation --operation为条件语句表达式, (…
sql允许多层嵌套,子查询是嵌套在其他查询中的查询.我们可以把子查询当做一张表来看到,即外层语句可以把内嵌的查询结果当做一张表使用. 子查询查询结果有三种情况 不返回查询记录.若子查询不返回记录则主查询也不会有查询记录 查询单行记录.若子查询返回的是单行记录,则在主查询中可以对该单行记录使用比较运算符 查询多行记录.若子查询返回多行记录,则在主查询中不能对该子查询记录使用比较运算符 条件比较=,!=,<>,<,>,<=,>=,any,some,allis null,is…