Oracle学习总结_day05_集合_连接查询
本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用.
**转载请注明 出自 : luogg的博客园 ** 谢谢配合!
day05_集合_连接查询
集合操作符
UNION (并集 ,去除重复行)
查询工资大于8000或职位是程序员的雇员的姓名、工资、职位id --37
select first_name,salary,job_id from copy_emp where salary>4000 --37
union
select first_name,salary,job_id from copy_emp where job_id='IT_PROG'; --5
--union all(A+B,不会去除重复的行) --42
select first_name,salary,job_id from copy_emp where salary>4000 --37
union all
select first_name,salary,job_id from copy_emp where job_id='IT_PROG'; --5
--intersect 取查询结果交集C --5
--查询工资大于8000且职位是程序员的雇员的姓名、工资、职位id
select first_name,salary,job_id from copy_emp where salary>4000 --37
INTERSECT
select first_name,salary,job_id from copy_emp where job_id='IT_PROG';--5
--minus(A-B) 的用法 : 显示在A 中存在, 而在B 中不存在 --32
select first_name,salary,job_id from copy_emp where salary>4000 --37
MINUS
select first_name,salary,job_id from copy_emp where job_id='IT_PROG';--5
连接查询 :
1. 自连接 : 自己表内连接,比如员工表中员工id和上级的员工id.
--自连接的练习使用
--名字,salary,部门编码,部门的名称,工资等级,上级名称
select
worker.first_name,worker.salary,worker.department_id,department_name,grade,leader.first_name
from copy_emp worker,copy_emp leader,salgrade,copy_dept dept
where worker.manager_id=leader.employee_id
and worker.salary between losal and hisal
and worker.department_id = dept.department_id;
2. 等值连接 :
3. 非等值连接 :
--查询员工工资和等级(非等值连接 )
select first_name || ',' || last_name as "姓名",employee_id,salary,grade
from copy_emp ce,salgrade2 sg
where ce.salary BETWEEN losal AND HISAL;
4. 内连接 :
--查看部门内雇员编号、姓名、所在部门编号以及部门的名称
select employee_id,first_name,emp.department_id,department_name
from copy_emp emp INNER JOIN copy_dept dept
ON emp.department_id=dept.department_id;
5. 外连接 :
--左外连接(左边的表做了主表与右侧的表关联,右外连接相反)
--查看所有部门 (包含没有员工的部门 ) 的雇员编号、姓名、所在部门编号以及部门名称
select employee_id,first_name,emp.department_id,department_name
from copy_emp emp
LEFT JOIN copy_dept dept
ON emp.department_id=dept.department_id;
--多条件左外连接 名字,salary,部门编码,部门的名称,工资等级,上级名称
select worker.first_name,worker.salary,worker.department_id,department_name,grade,leader.first_name
from copy_emp worker
LEFT JOIN copy_emp leader
ON worker.manager_id=leader.employee_id
LEFT JOIN copy_dept dept
ON worker.department_id=dept.department_id
LEFT JOIN salgrade
ON worker.salary between losal and hisal;
--用 (+) 代替左外连接或右外连接,位置相反
select first_name,emp.employee_id
from copy_emp emp,copy_dept dept
where emp.department_id=dept.department_id(+)
6. 全连接 :
rownum 使用
--查询工资前三的员工信息
select rownum,a.* from (select rownum,emp.* from copy_emp emp) a
where rownum <=3 order by salary nulls last;
--工资6-10 的员工信息
select rownum,a.* from (select rownum,emp.* from copy_emp emp) a
where rownum <=10
minus
select rownum,a.* from (select rownum,emp.* from copy_emp emp) a
where rownum <=6
课外补充:
--1.查询没有员工的部门信息
select * from copy_dept where department_id not in(select department_id from copy_emp
where department_id is not null group by department_id)
--2.查询没有部门的员工信息
select * from copy_emp where department_id is null;
--思特奇 查询出只有主功夫 没有次功夫的员工信息( 信息包含 员工名字,部门名称,功夫描述,个人资产 )
select * from dept_info;
select * from kf_info;
select * from user_info;
select * from user_kongfu;
select ukf.user_id,uinfo.name,dinfo.dept_name,kinfo.kf_name,uinfo.user_asset,ukf.main_kf_flag
from user_kongfu ukf,user_info uinfo,dept_info dinfo,kf_info kinfo
where uinfo.user_id=ukf.user_id
and dinfo.dept_no=uinfo.dept_id
and kinfo.kf_id = ukf.kf_id
and ukf.user_id not in(select user_id from user_kongfu where main_kf_flag=0 group by user_id)
Oracle学习总结_day05_集合_连接查询的更多相关文章
- mysql学习之路_连接查询
回顾 列属性:主键,自增长,唯一键. 关系:一对一,一对多,多对多 三层范式: 1NF:字段设计必须符合原子性 2NF:不存在部分依赖(没有复合主键) 3NF:不存在传递依赖(实体单独成表) 逆规范化 ...
- 【学习笔记】Hibernate HQL连接查询和数据批处理 (Y2-1-7)
HQL连接查询 和SQL查询一样 hql也支持各种链接查询 如内连接 外连接 具体如下 左外连接 left (outer) join 迫切左外连接 left (outer) join fetch 右外 ...
- mysql_数据查询_连接查询
连接查询 1.连接(join) 也称θ连接,从两个关系的笛卡尔积中选择属性间满足一定条件的元组. 等值连接:θ为“=”的连接运算称为等值连接.从关系R和S的广义笛卡尔积中选取A.B属性值相等的元组. ...
- MySQL学习(四) SQL连接查询
更多情况下,我们查询的数据来源于多张表,所有有必要了解一下MySQL中的连接查询. SQL中将连接查询分成四类:交叉连接,内连接,外连接和自然连接. 数据准备 student表 -- -------- ...
- MySQL学习笔记(十二)__连接查询(一)
连接查询含义:又称多表查询,当查询的字段来自多个表时,就会用到连接查询 笛卡尔乘积现象:表1 有 m 行,表2 有 n 行,结果 = m*n 行发生原因:没有有效的连接条件如何避免:添加有效的连接条件 ...
- 【Java EE 学习 28 上】【oracle学习第二天】【子查询】【集合运算】【几种数据库对象】
一.子查询 1.为什么要使用子查询:问题不能一步求解或者一个查询不能通过一步查询得到. 2.分类:单行子查询和多行子查询. 3.子查询的本质:一个查询中包含了另外一个或者多个查询. 4.使用子查询的规 ...
- Oracle 学习笔记 14 -- 集合操作和高级子查询
Oracel提供了三种类型的集合操作:各自是并(UNION) .交(INTERSECT). 差(MINUS) UNION :将多个操作的结果合并到一个查询结果中,返回查询结果的并集,自己主动去掉反复的 ...
- Oracle学习(二)_多表操作
--第一部分:SQL基础 --ch1 简单查询 --ch2 查询基本概念 --ch3 数据过滤 --第二部分:多表操作 --ch4 集合理论 --ch5 内连接 --ch6 外连接 --ch7 子查询 ...
- Oracle学习笔记(7)——高级查询(1)
在学习高级查询之前,我们先了解一下怎样查看Oracle数据库中的全部表.由于我们要使用到Oracle数据库中SCOTT用户下的几张表(这些表是Oracle数据库自带的表). 分组查询 分组函数的概念: ...
随机推荐
- 学习SpringMVC——从HelloWorld开始
前言: 时隔十二年,中国女排最终过关斩将,用3:1的成绩证明了自己的实力,霸气夺冠,为中国赢得了一枚意义非常的金牌.这是一次全民的狂欢,一场视听盛宴,带给我们不仅是熠熠生辉的金牌,更传递出的是一种女排 ...
- UWP自动填充控件AutoSuggestBox小优化
UWP提供的AutoSuggestBox本身非常好用,在项目中经常用到,但是当我们使用时发现一下不人性化的设置,例子1如下: <Page x:Class="SelfInkCanvas. ...
- Intellij IDEA 13.1.3 打开多个窗口项目
作者QQ:1095737364 Intellij 是Java开发人员最喜欢的编程工具.默认情况只能打开一个窗口一个项目,本文就是教大家打开多个窗口,实现同时打开多个项目 第一步:打开Intellij, ...
- HTML5 音频播放器-Javascript代码(短小精悍)
直接上干货咯! //HTML5 音频播放器 lzpong 2015/01/19 var wavPlayer = function () { if(window.parent.wavPlayer) re ...
- dede在php7上空白
最近想看一本小说,想采集回来看,结果发现除了dedecms支持php7.0,其他主流cms基本上都不支持php7.0 在本地win7上调试了一遍,没有问题,放到linux服务器上的时候,发现打开任何页 ...
- 工作任务:模拟淘宝登录和购物车功能:使用cookie记录登录名,下次登录时能够记得上次的登录名,使用cookie模拟购物车功能,使用session记住登录信息并验证是否登录,防止利用url打开网站,并实现退出登录功能
登入界面<% Cookie[] cks =request.getCookies(); String str=null; for(Cookie ck:cks) { if(ck.getName(). ...
- jQuery 2.0.3 源码分析core - 选择器
声明:本文为原创文章,如需转载,请注明来源并保留原文链接Aaron,谢谢! 打开jQuery源码,一眼看去到处都充斥着正则表达式,jQuery框架的基础就是查询了,查询文档元素对象 ...
- python统计某一个进程名所占用的内存
设计思路: 通过python,执行cmd中tasklist命令,获取要统计的进程的相关信息:通过正则表达式,查找出进程名称.进程pid.内存使用,然后打印出来. 作为pythoner,有时候需要统计p ...
- javascript中15种原生对象类型系统综述
前面的话 在编程语言中,能够表示并操作的值的类型称做数据类型,编程语言最基本的特性就是能够支持多种数据类型.javascript拥有强大的类型系统,主要包括原生对象.宿主对象和浏览器拓展对象,本文主要 ...
- js 根据屏幕大小调用不同的css文件
原因:屏幕大小不一样,网站看起来总觉得怪怪的,所以,针对不同大小的屏幕,写了不同的css,写完了,要解决的问题就是:怎么根据屏幕的大小来引用不同的CSS,下面就是解决方法了. 解决方法:首先,在hea ...