不等值连接查询

  • 员工工资级别
  • 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. Java Web获取Web应用根路径

    最基本的 1,request.getRealPath("/");这个方法已不推荐用 2,在Servlet 里用this.getServletContext().getRealPat ...

  2. #分组背包 Educational Codeforces Round 39 (Rated for Div. 2) D. Timetable

    2018-03-11 http://codeforces.com/contest/946/problem/D D. Timetable time limit per test 2 seconds me ...

  3. POJ 1038 Bugs Integrated, Inc.(DFS + 三进制状压 + 滚动数组 思维)题解

    题意:n*m方格,有些格子有黑点,问你最多裁处几张2 * 3(3 * 2)的无黑点格子. 思路:我们放置2 * 3格子时可以把状态压缩到三进制: 关于状压:POJ-1038 Bugs Integrat ...

  4. Python自学:第三章 在列表末尾添加元素与在列表中插入元素

    motorcycles = ['honda', 'yamaha' ,'suzuki'] motorcycles.insert(0, "ducati") print(motorcyc ...

  5. 普元eos、soa、esb

    http://www.primeton.com/support/video.php http://www.primeton.com/products/bps/overview.php http://w ...

  6. selenium java ,执行js改变页面

    1.面对页面一些页面上的限制而导致某些选择按钮无法选中的问题 很多时候由于页面上的一些限制会导致我们无法无法正常用webdriver来实现我们手动的正常操作,这时候我们可以通过执行js来适当的改变页面 ...

  7. React文档(十三)思考React

    在我们的看来,React是使用js创建大型快速网站应用的首要方法.它在Facebook和Instagram的使用已经为我们展现了它自己. React的一个很好的地方就在于当你创建应用的时候它使你思考如 ...

  8. jQuery中的 $.ajax的一些方法

    1. $(document).ajaxConplete(function(){}) 1.8版本之后,只能绑定到document元素上:1.8版本之前,可以帮到其他元素上 当$.ajax执行完成之后,执 ...

  9. sublim 配置 用户默认绑定的格式化文本快捷键

      //在绑定用户绑定配置中 加入 激活每个字母提示! "auto_complete": true,"auto_match_enabled": true, &q ...

  10. 【网址】.net/dot net可再发行组件下载哪家强

    微软开发者文档中有篇文章包含了.net/dot net各版本下载全家福: https://msdn.microsoft.com/zh-cn/library/5a4x27ek.aspx 安全可靠.没有三 ...