Oracle笔记_多表查询
3.1 执行sql文件
@文件地址名 --执行某个sql文件;
3.2 多表查询
想要的数据不在同一张表,就需要多个表进行联查。
多表查询也叫做表连接查询,其中的where条件就是连接条件。
可以使用join来进行表连接,from 中的逗号换成join ,where换成on即可,join后面还可以另外跟where条件。
select ...
from 表1,表2...
where...
...
3.3 外连接
保留没有通过连接条件筛选的数据的时候使用外连接。
oracle用法
- 想保留哪一张表的数据,应该在连接条件等号的另一边使用(+);
select d.deptno,d.dname,count(empno)
from dept d, emp e
where d.deptno = e.deptno(+)
group by d.deptno,d.dname
sql用法
select d.deptno,d.dname,count(empno)
from dept d join emp e
on d.deptno = e.deptno
group by d.deptno,d.dname
3.4 自连接
表自己跟自己做多表连接查询,要查询的数据在同一张表但是不在同一行,就要使用自连接
select a.ename||'''s manager is '||nvl(b.ename,' his wife')
from emp a, emp b
where a.mgr = b.empno(+)
3.5 子查询
个查询的select语句里边嵌套了另一个select语句;
select * from emp
where sal > (select sal from emp where ename = 'SCOTT')
注意事项
父查询和子查询可以是不同的表,子查询返回的结果父查询可以使用即可;
父查询的select、from、where、having都可以嵌套子查询;
单行子查询只能使用单行操作符,多行子查询只能使用多行操作符,单行操作符,就是对某个单一数据的比较操作 =|>|>=|<|<=等;
多行操作符,就是对一个集合的比较操作(IN、ANY、ALL)
select * from emp
where deptno in (select deptno from dept
where dname ='SALES' or dname = 'ACCOUNTING')
- 子查询中返回的null值影响最终计算结果;
select * from emp
where empno not in (select mgr from emp where mgr is not null)
3.6 集合运算
并集 union
全并集 union all
交集 intersect
差集 minus
select * from emp where deptno = 10
union
select * from emp where deptno = 20
用命令break on deptno skip 2来去掉分组重复的deptno,使用break on null恢复;
注意事项
参与运算的各个集合必须列数相同,且类型一致;
采用第一个集合的表头作为最终使用的表头,(别名也只能在第一个集合上起);
可以使用括号修改各个sql执行的优先级;
3.7 新增数据
insert into 表名 values(val1,val2,.....) val1 val2 这些值要对应表的每列顺序
insert into 表名(列名,列名2.....) values(val1,val2,.....)
字符串和日期加单引号;
"&"符号,可简化增删查改操作
- 例:select * from &t; 再次输入/时,可快速查找;
批处理
--一次性将emp表中所有10号部门的员工,放到新表emp10中来。
insert into emp10 select * from emp where deptno=10 ; --一次性将 emp表中的指定列插入到表emp10中。
--注意:insert的列名,要和select的列名一致
insert into emp10(empno, ename, sal, deptno)
select empno, ename, sal, deptno from emp
where deptno=10;
--注意没有values关键字了。且列名必须一一对应
3.8 修改数据
update 表名 set 列名1=值1,列名2=值2..... [where cond]
- 例:update dept set dname='SUPPORT1',loc=null where deptno=50;
3.9 删除数据
delete from 表名 [where cond]
- 例:delete from dept where deptno=50
3.10 rownum
rownum 是行号,伪列,并不是真实存在于表中的列,最好在排序前生成;
rownum只能使用<, <=符号,不能使用>,>=符号,除了>=1
- select rownum,emp.* from emp order by sal desc;
Oracle笔记_多表查询的更多相关文章
- SQL基本查询_单表查询(实验二)
SQL基本查询_单表查询(实验二) 查询目标表结构及数据 emp empno ename job hiedate sal comn deptno 1007 马明 内勤 1992-6-12 4000 2 ...
- SQL基本查询_多表查询(实验三)
SQL基本查询_多表查询(实验三) 题目要求(一) 针对emp.dept两表完成如下查询,并验证查询结果的正确性 使用显式内连接查询所有员工的信息,显示其编号.姓名.薪水.入职日期及部门名称: 使用隐 ...
- oracle系列笔记(2)---多表查询
多表查询 这篇文章主要讲四点: (1)oracle多表查询 (2)SQL99标准的连接查询 (3)子查询 (4)分级查询 oracle多表查询有两种方式,一种是oracle所 ...
- Oracle学习笔记_04_多表查询
一.概念: 1.多表连接有以下几种分法: (1)内连接 vs 外连接 (左.右.满) (2)等值连接 vs 不等值连接 (3)非自连 ...
- Oracle数据库之单表查询
接着上一篇的分享,今天主要给大家分享的是关于数据中的单表查询,单表查询很基础,也很重要,但是任何一个初学者必须要掌握的姿势,单表查询就是对单个表进行操作,查询我们想要的数据.单表查询里面的内容也是比较 ...
- Oracle中的多表查询(笛卡尔积原理)
本次预计讲解的知识点 1. 多表查询的操作.限制.笛卡尔积的问题: 2. 统计函数及分组统计的操作: 3. 子查询的操作,并且结合限定查询.数据排序.多表查询.统计查询一起完成各个复杂查询的操作: 一 ...
- Oracle(2)之多表查询&子查询&集合运算
多表查询 笛卡尔积 同时查询多张表时,每张表的每条数据都要和其它表的每条数据做组合.如下栗子,我们发现产生的总记录数是 56 条,还发现 emp 表是 14 条,dept 表是 4 条,56 条正是 ...
- mysql_数据查询_单表查询
1.单表查询: 1.1选中表中若干列: SELECT子句的<目标列表达式>可以是表中属性列,也可以是表达式,还可以是字符常量. SELECT Sname,'year of birth:', ...
- Oracle数据库之七 多表查询
七.多表查询 对于查询在之前已经学过了简单查询.限定查询.查询排序,这些都属于 SQL 的标准语句,而上一章的单行函数,主要功能是为了弥补查询的不足. 而从多表查询开始就正式进入到了复杂查询部 ...
随机推荐
- Scala数据结构
Scala数据结构 主要的集合特质 Scala同时支持可变集合和不可变集合,优先采用不可变集合.集合主要分为三大类:序列(List),集(set),映射(map).所有的集合都扩展自Iterable特 ...
- TensorFlow笔记-文件读取
小数量数据读取 这些只用于可以完全加载到内存中的小型数据集: 1,储存在常数中 2,储存在变量中,初始化后,永远不改变它的值 使用常量 training_data = ... training_lab ...
- [leetcode] 929. Unique Email Addresses (easy)
统计有几种邮箱地址. 邮箱名类型:local@domain 规则:1. local中出现"."的,忽略. a.bc=abc 2. local中出现"+"的,+以 ...
- [leetcode] 111.Mininum Depth of Binary Tree (Easy)
原题 寻找二叉树最短深度 这里用了dfs,beat 100%,4ms class Solution { public: int minDepth(TreeNode *root, int minNum ...
- WebGL中深度碰撞方法总结
z-fighting问题是三维渲染中常见的问题,本文根据实际工作中遇到的一些场景,进行了系统的总结 一个实际工作中的问题 当两个面离得太近就会发生深度碰撞问题,比如: 遇到深度检测问题,最重要的是先搞 ...
- linux初学者-普通磁盘分区篇
linux初学者-普通磁盘分区篇 磁盘是计算机的重要组成部分,是记录数据的场所.在使用磁盘时,经常需要对其进行分区来实现不同的用途.下文将介绍在linux系统中普通磁盘分区的方法. "fdi ...
- Unity3D热更新之LuaFramework篇[08]--热更新原理及热更服务器搭建
前言 前面铺垫了这么久,终于要开始写热更新了. Unity游戏热更新包含两个方面,一个是资源的更新,一个是脚本的更新. 资源更新是Unity本来就支持的,在各大平台也都能用.而脚本的热更新在iOS平台 ...
- 初探java流操作
在处理集合时,我们通常会迭代遍历它的元素,并从每个元素上执行某项操作.例如,假设我们想要对某本书中的所有长单词进行计数.首先我们要将所有单词放入一个列表中: String contents = new ...
- 第二章 :初识MySQL
一.MySQL 1. MySQL的版本 社区版 企业帮 2.MySQL的优势 1.运行速度快 2.使用成本低 3.容易使用 4.可移植性高 5.适用更多用户 二.默认字符集设置 1.Standard ...
- C语言编程入门之--第三章编写第一个C语言程序
第三章 编写第一个C语言程序 导读:一般学一门计算机语言的第一堂上机课(“上机”顾名思义,上了计算机),就是往屏幕输出“hello world”,本章也不例外. 1.1 Hello,World! 这一 ...