关联查询

笛卡尔积
指做关联操作的每个表的每一行都和其他表的每一行组合,假设两个表的记录条数分别为x和y,笛卡尔积将返回x*y条记录
例如:select count(*) from emp;
select count(*) from dept;
select emp.ename,dept.dname from emp,dept;

等值连接
连接查询中最常见的一种,通常是在有主外键关联关系的表之间建立,并将连接条件设定为有关系的列,使用“=”连接相关的表
例如:查询职员的姓名、职位以及所在部门的名字和所在城市
select e.ename,e.job,d.dname,d.loc
from emp e,dept d
where e.deptno=d.deptno;

内连接
返回所有满足条件的记录
例如:查询职员的姓名、职位以及所在部门的名字和所在城市
select e.ename,e.job,d.dname,d.loc
from emp e,dept d
where e.deptno=d.deptno;
或者(如果要写内练接,就用下面这个)
select e.ename,e.job,d.dname,d.loc
from emp e join dept d
on (e.deptno=d.deptno);

外连接
不仅返回满足条件的记录,还将返回不满足条件的记录
select table1.column,table2.column
from table1 left|right|full[outer] join tanle2
on table1.column=table2.column;

例如:查询职员的姓名、职位以及所在部门的名字和所在城市
左外连接
select e.ename,e.job,d.dname,d.loc
from emp e left outer join dept d
on e.deptno=d.deptno;
右外连接
select e.ename,e.job,d.dname,d.loc
from emp e right outer join dept d
on e.deptno=d.deptno;
全外连接
select e.ename,e.job,d.dname,d.loc
from emp e full outer join dept d
on e.deptno=d.deptno;

自连接
是一种特殊的连接查询,数据的来源是同一个表,也就是说关联关系来自于单表中的多个列
表中的列参照同一个表中的其它列的情况称作自参照表
自连接是通过将表用别名虚拟成两个表的方式实现,可以是等值或不等值连接
例如:查询出每个职员的经理的名字以及他们的职员编号
select worker.empno w_empno, worker.ename w_ename,manager.ename m_ename,manager.empno m_empno
from emp worker join emp manager
on worker.mgr=manager.empno;

----------------------------------------------------------------------------------------

子查询
子查询在where子句中
在select查询中,在where查询条件中的限制条件不是一个确定的值,而是来自于另一个查询的结果
为了给查询提供数据而首先执行的查询语句叫子查询
子查询是嵌入在其他SQL语句中的select语句,大部分出现在where子句中
子查询嵌入的语句称作主查询或者父查询
主查询可以是select语句,也可以是其他sql语句中

根据返回结果的不同,子查询可以分为单行子查询、多行子查询和多列子查询
例如:查询和Scott同职位的员工
select ename from emp where job=(select job from emp where ename='SCOTT');

rownum
被称作为伪列,用于返回标识行数据顺序的数字
select rownum,empno,ename,sal from emp;

例如:查询出emp表第三条以后的数据
select * from (select rownum rm,e.* from emp e) where rm>3;
查询出emp表第三条到第七条数据
select * from (select rownum rm,e.* from emp e) where rm between 3 and 7;

使用子查询进行分页
分页策略:每次只取一页的数据,每次换页,取下一页的数据
在oracle中利用rownum的功能可用来进行分页,假设结果集共有105条数据,每页20条数据,那么
page1:1-20
page2:21-40
...
pageN:pagesize*(currentpage-1)+1 pagesize*currentpage

例如:按照薪水倒序排列,去除结果集中第8-10条记录
select * from (select rownum rm,sal from (select * from emp order by sal desc) ) where rm between 8 and 10;

查询emp表,根据职员的职位计算奖金额,管理者1.2倍工资、办事员1.1倍工资、销售员1.05倍工资,如果不是这三个职位的就取工资值。
decode函数解决此类问题
decode(column,search1,result1,search2,result2... ,result)

select ename,job,sal, decode(job,'MANAGER',sal*1.2,'ANALYST',sal*1.1,'SALESMAN',sal*1.05,sal) bonus from emp;
等同于
select ename,job,sal,case job when 'MANAGER' then sal*1.2
when 'ANALYST' then sal*1.1
when 'SALESMAN' then sal*1.05
else sal end bonus
from emp;

根据年薪算
select ename,job,sal,comm,decode(
job,
'MANAGER',(sal+nvl(comm,0))*12*0.5,
'ANALYST',(sal+nvl(comm,0))*12*0.4,
'SALESMAN',(sal+nvl(comm,0))*12*0.3,
(sal+nvl(comm,0))*12*0.1
) bonus from emp;

多列子查询

exists操作符
检查子查询中是否满足条件的行
1--如果在子查询中存在满足条件的行,返回true,就不再子查询继续查找
2--如果子查询中不存在满足条件的行,就返回false,继续在子查询中查找

Oracle学习第三讲的更多相关文章

  1. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  2. Oracle学习线路

    出自huyangg的博客,地址是:oracle学习路线图 1.sql.pl/sql(网上有很多的视频,可以做一个简单的入手,然后看几本书,多做实验)    作为oracle的基本功,需要大家对sql和 ...

  3. Oracle学习指南

    Oracle学习指南 你走的那天,我决定不落泪,迎着风撑着眼帘用力不眨眼 创建数据库.创建用户.创建表空间.创建表.插入数据..... 1.用系统用户登录,任选系统用户 代码: >>sql ...

  4. Oracle学习系列1-7

    Oracle学习系列1 两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 3 ...

  5. Oracle学习系列7

    Oracle学习系列7 ************************************************************************************ 关联表 ...

  6. Oracle学习系列6

    Oracle学习系列6 ************************************************************************************ 删除约 ...

  7. Oracle学习系列5

    Oracle学习系列5 ************************************************************************************ ,掌握 ...

  8. Oracle学习系列4

    Oracle学习系列4 ************************************************************************************ 数据库 ...

  9. Oracle学习系列3

    Oracle学习系列3 ************************************************************************************ 多表查 ...

随机推荐

  1. Android-adb shell 读取手机系统文件

    1.首先保证手机是root 状态 2.运行 adb shell 页面以后 su root 3.ls 就会发现目录结构可以显示了

  2. wpa_supplicant 配置与应用

    概述 wpa_supplicant是wifi客户端(client)加密认证工具,和iwconfig不同,wpa_supplicant支持wep.wpa.wpa2等完整的加密认证,而iwconfig只能 ...

  3. HDU-1395 2^x mod n = 1

    http://acm.hdu.edu.cn/showproblem.php?pid=1395 怎样取余是关键.. 2^x mod n = 1 Time Limit: 2000/1000 MS (Jav ...

  4. NodeAsp——像开发NodeJS应用一样玩转ASP

    NodeAsp是一套Classic ASP框架,借鉴了NodeJS的模块化思想,让您可以使用全新的理念愉快地书写ASP程序. NodeAsp使用遵循CommonJS规范的require,完全兼容Nod ...

  5. [并发编程]使用线程安全队列和条件变量的notify来安排分步骤任务

    // 方法1:直接构建N个THread来run foreach (i, size) { thread trd(&Instance::doWork, &inst); lstTrd.pus ...

  6. 矩阵乘法 and BIOS loads MBR into 0x7C00?

    tianpeng <再谈矩阵与矩阵乘法> 讲的也好 矩阵乘矩阵 这个结果是怎么算出来的? 第一个矩阵第一行的每个数字(2和1),各自乘以第二个矩阵第一列对应位置的数字(1和1),然后将乘积 ...

  7. 让你的Ubuntu也能像Windows那样显示网速和CPU温度

    致力于Linux桌面操作系统的平民化,一直强迫自己完全在Ubuntu系统下进行日常的电脑使用,但是用长了时间的Windows,还是有些习惯改不过来,比如只要在下载或者看在线视频的时候就会不自觉关注网速 ...

  8. Using Java SecurityManager to grant/deny access to system functions

    In Java it is possible to restrict access to specific functions like reading/writing files and syste ...

  9. hdoj 4738 Caocao's Bridges【双连通分量求桥】

    Caocao's Bridges Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  10. Unity EditorWindow 笔记

    一:功能 1.实例化 //设置插件在菜单栏的位置 和快捷键 [MenuItem("YCC's Tools/模型更改/更改父物体和测量长度 %W")] //实例化窗体 static ...