oracle query
不等值连接查询
- 员工工资级别
- 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的更多相关文章
- paip.oracle query export to insert sql
paip.oracle query export to insert sql 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http:/ ...
- Oracle query that count connections by minute with start and end times provided
数据结构类似 SQL> select * from t; B E N ----------------- ------------ ...
- Python中通过cx_oracle操作ORACLE数据库的封闭函数
哈哈,看来我的SQL自动化发布,马上就全面支持ORACLE,MYSQL,POSTGRESQL,MSSQL啦... http://blog.csdn.net/swiftshow/article/deta ...
- 老李分享: Oracle Performance Tuning Overview 翻译
老李分享: Oracle Performance Tuning Overview 翻译 poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工 ...
- 数据库隔离级别深入理解(ORACLE)
TRANSACTION_READ_UNCOMMITTED 1 这种隔离级别最低,脏读,不可重复读,幻读都会发生,我用的oracle,并没有支持这个级别,不作研究. TRANSACTION_READ_C ...
- redash oracle 数据源docker 镜像
redash 官方的docker 镜像是没有包含oracle的,需要我们自己添加,参考了一个docker 镜像进行了简单的修改 Dockerfile FROM redash/redash:7.0.0. ...
- oracle_fdw安装及使用(无法访问oracle存储过程等对象)
通过oracle_fdw可以访问oracle中的一些表和视图,也可以进行修改,尤其是给比较复杂的系统使用非常方便. (但不能使用oracle_fdw来访问oracle的存储过程.包.函数.序列等对象) ...
- sqluldr2 oracle直接导出数据为文本的小工具使用
近期客户有需求,导出某些审计数据,供审计人进行核查,只能导出成文本或excel格式的进行查看,这里我们使用sqluldr2工具进行相关数据的导出. oracle导出数据为文本格式比较麻烦,sqluld ...
- 初步认知MySQL metadata lock(MDL)
http://blog.itpub.net/26515977/viewspace-1208250/ 概述 随着5.5.3引入MDL,更多的Query被“Waiting for table metada ...
随机推荐
- linux驱动编写(pwm驱动)【转】
本文转载自:https://blog.csdn.net/feixiaoxing/article/details/79889240 pwm方波可以用来控制很多的设备,比如它可以被用来控制电机.简单来说, ...
- 【C++】10.18日的C++笔记
使用memset初始化一个类会导致类中的指针和虚函数表出现问题.相关链接 使用memset(a,1,sizeof(a))初始化a数组不会达到预期的效果,因为memset会把每个字节赋值为1就会变成16 ...
- RN中API之NetInfo--浅谈
我们在做移动端项目和手机APP应用时,避免不了要获取用户手机的网络状况.在使用RN技术开发APP时,其内置的NetInfo API就是为了解决这一问题的.下面简单的讲下NetInfo如何使用. 最新的 ...
- java基础 (四)之集合
List集合中的元素可以重复 ArrayList:数组,查询比较快 LinkedList:链表,常用于增删改效率高 Vector:线程安全,synchronized 线程安全的写法:Collectio ...
- servelet基础
1.1 servlet简介 Java Servlet 是运行在 Web 服务器或应用服务器上的程序.她是一个浏览器和服务器之间的中间层.程序员开发程序,实现servlet的接口.S ...
- 第 8 章 容器网络 - 068 - 分析 Calico 的网络结构
分析 Calico 的网络结构 在 host1 中运行容器 bbox1 并连接到 cal_net1: docker container run --network cal_net1 --name bb ...
- js中提示框闪退问题
当页面存在刷新 或 在线引用iframe框架时(引用框架也会导致刷新) 会导致页面加载时的弹出框闪退 解决方法:设置弹出框在页面或者框架完全加载一段时间后再弹出 <script type=& ...
- Petrozavodsk Winter Camp, Andrew, 2014, Bipartite Bicolored Graphs
由i个点和j个点组成的二分图个数为 $3^{ij}$,减去不联通的部分得到得到由i,j个点组成的联通二分图个数 $g_{i,j} = 3_{ij} - \sum_{k=1}^i \sum_{l=0}^ ...
- MVC实战之排球计分(六)—— 使用EF框架,创建Controller,生成数据库。
在上篇博客我们写到,此软件的数据库连接我们使用的是EF框架,code first模式下, 通过模型类,在创建controller的时候直接生成数据库,完成数据库的连接,与操作. 在使用EF框架之前,我 ...
- 【Mybatis】【1】generate批量生成实体类,数据库接口类和mapper
前言: 1,实体类之类如果自己写的话,比较繁琐,还容易出错,所以用generate自动生成 2,int类型可能会生成为short类型,建议不要手动改回int类.因为下次生成又是short类型了,可能会 ...