不等值连接查询

  • 员工工资级别
  • select e.empno,e.ename,e.sal,s.grade
  • from emp e,salgrade s
  • where e.sal between s.losal and s.hisal

外连接

  • 外连接的意义:对于某些不成立的记录,仍然希望包含在最后的结果集中。

  • 左外连接:当where e.deptno = d.deptno 不成立时,等号左边表的任意项仍被包含

  • 左外连接写法: where e.deptno = d.deptno(+)

  • 右外连接写法: where e.deptno = d.deptno(+)

  • 按部门统计员工人数:部门号,部门名称,人数, (右外连接)

  • select d.deptno, d.dname,count(e.empno)

  • from emp e,dept d

  • where e.deptno(+) = d.deptno

  • group by d.deptno, d.dname

  • order by d.deptno

层次查询

  • 只有一张表,单表查询,自连接为多表查询
  • select level, empno, ename, mgr
  • from emp
  • connect by prior empno = mgr
  • start with mgr is null
  • order by 1
  • level 为伪列,显示层次中的级别

子查询

  • 可以在主查询的where, select, having, from 后放置子查询
  • 不可以在group by后放置子查询
  • 主查询和子查询可以不是同一张表,只要子查询返回的结果主查询可用即可
  • 一般不在子查询中使用排序,但在Top-N的子查询中要排序
  • 子查询一般在主查询执行前执行完成,但相关子查询例外
  • 单行子查询(即只返回一条记录的查询)只能使用单行操作符,多行子查询只能使用多行操作符

多行子查询

  • 返回多行,使用多行比较操作符
  • in: 等于列表中的任何一个
  • any:和子查询返回的任意一个值比较(min())
  • all:和子查询返回的所有制比较(max())
  • 查询工资比30号部门任意一个员工高的员工
  • select * from emp where sal > any(select sal from emp where deptno = 30);
  • 不是老板的员工,所有的叶子节点
  • select * from emp where empno not in (select mgr from emp where mgr is not null);
  • 找到员工中工资最高的前3名
  • select rownum, empno, ename, sal
  • from (select * from emp order by sal desc)
  • where rownum <= 3;
  • 找到员工表中薪水大于本部门平均薪水的员工
  • select e.empno,e.ename,e.sal,d.avgsal
  • from emp e, (select deptno, avg(sal) avgsal from emp group by deptno) d
  • where e.deptno = d.deptno and e.sal > d.avgsal

相关子查询

  • 将主查询中的某些值作为参数传递给子查询
  • 找到员工表中薪水大于本部门平均薪水的员工
  • select e.empno, e.ename,e.sal, (select avg(sal) from emp where deptno = e.deptno) avgsal
  • from emp e
  • where e.sal > (select avg(sal) from emp where deptno = e.deptno)
  • 统计每年入职人数

    select count(*) Total,

    sum(decode(to_char(hiredate, 'yyyy'), '1980', 1, 0)) "1980",

    sum(decode(to_char(hiredate, 'yyyy'), '1981', 1, 0)) "1981",

    sum(decode(to_char(hiredate, 'yyyy'), '1982', 1, 0)) "1982",

    sum(decode(to_char(hiredate, 'yyyy'), '1987', 1, 0)) "1987"

    from emp;

分页

select *
from (select rownum r, e1.*
from (select * from emp order by sal) e1
where rownum <=8 )
where r >= 5;

oracle query的更多相关文章

  1. paip.oracle query export to insert sql

    paip.oracle query export to insert sql 作者Attilax ,  EMAIL:1466519819@qq.com  来源:attilax的专栏 地址:http:/ ...

  2. Oracle query that count connections by minute with start and end times provided

    数据结构类似 SQL> select * from t; B                 E                 N ----------------- ------------ ...

  3. Python中通过cx_oracle操作ORACLE数据库的封闭函数

    哈哈,看来我的SQL自动化发布,马上就全面支持ORACLE,MYSQL,POSTGRESQL,MSSQL啦... http://blog.csdn.net/swiftshow/article/deta ...

  4. 老李分享: Oracle Performance Tuning Overview 翻译

    老李分享: Oracle Performance Tuning Overview 翻译   poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工 ...

  5. 数据库隔离级别深入理解(ORACLE)

    TRANSACTION_READ_UNCOMMITTED 1 这种隔离级别最低,脏读,不可重复读,幻读都会发生,我用的oracle,并没有支持这个级别,不作研究. TRANSACTION_READ_C ...

  6. redash oracle 数据源docker 镜像

    redash 官方的docker 镜像是没有包含oracle的,需要我们自己添加,参考了一个docker 镜像进行了简单的修改 Dockerfile FROM redash/redash:7.0.0. ...

  7. oracle_fdw安装及使用(无法访问oracle存储过程等对象)

    通过oracle_fdw可以访问oracle中的一些表和视图,也可以进行修改,尤其是给比较复杂的系统使用非常方便. (但不能使用oracle_fdw来访问oracle的存储过程.包.函数.序列等对象) ...

  8. sqluldr2 oracle直接导出数据为文本的小工具使用

    近期客户有需求,导出某些审计数据,供审计人进行核查,只能导出成文本或excel格式的进行查看,这里我们使用sqluldr2工具进行相关数据的导出. oracle导出数据为文本格式比较麻烦,sqluld ...

  9. 初步认知MySQL metadata lock(MDL)

    http://blog.itpub.net/26515977/viewspace-1208250/ 概述 随着5.5.3引入MDL,更多的Query被“Waiting for table metada ...

随机推荐

  1. URL和URI简单辨析

    URI 全称为 Universal Resource Identifier,统一资源标识符,用来唯一的标识一个资源. URL 全称为Universal Resource Locator,统一资源定位器 ...

  2. 160CrackMe第十九Brad Soblesky.2

    查壳无壳,vc写的. 我们输入假码后,然后点击,弹出错误框,直接打开od,对MessageBoxA下断点也行,寻找字符串也行. 一般的错误提示部分代码类似于这样. call xxx test xxx, ...

  3. 使用echarts时option可以复用的方法

    其实复用option很简单,在所要展示的图形在其他需求大致一致时,即可写一个option然后设置不同的地方就好了,坐标轴.series等都可以设置,具体代码如下: var barLeft = echa ...

  4. C#退出程序方法分类

    1.this.Close();   只是关闭当前窗口,若不是主窗体的话,是无法退出程序的,另外若有托管线程(非主线程),也无法干净地退出:

  5. 以太坊钱包开发系列2 - 账号Keystore文件导入导出

    以太坊去中心化网页钱包开发系列,将从零开始开发出一个可以实际使用的钱包,本系列文章是理论与实战相结合,一共有四篇:创建钱包账号.账号Keystore文件导入导出.展示钱包信息及发起签名交易.发送Tok ...

  6. js中字符串和正则相关的方法

    正则表达式对象常用方法 test() 检索字符串中指定的值.返回 true 或 false. var str="Embrace You" var r1=/you/i.test(st ...

  7. edu30F. Forbidden Indices

    题意:给你一个字符串s有一些位置被ban了,字符串t的价值是|t|*t在s中出现次数而且终点没有被ban.问你最大的价值是多少 题解:很明显t是s子串,建个sam,对于sam中每个位置,我们需要删除中 ...

  8. [hdu P3085] Nightmare Ⅱ

    [hdu P3085] Nightmare Ⅱ Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...

  9. 跟随我在oracle学习php(3)

    这次讲一下html中的列表和比较重要的表格 列表分为有序和无序,有序列表与无序列表都是块状元素 <ul>(父标签) 定义无序列表.复合标签(由父标签和子标签组成),不单独出现,用<l ...

  10. python之路-----网络编程

    一:客户端/服务端j架构(C/S架构) 在生活中,最常见的C/S架构即是APP和网页服务器这个架构.Client和Server之间利用网络来进行通信,客户端和服务器端的程序不同,用户的程序主要在客户端 ...