聚合函数:(都会忽略null数据)
常用的有5种:将字段中所有的数据聚合在一条中
、sum(字段名) :求总和 、avg(字段名) :求平均值 、max(字段名) :求最大值 、min(字段名) :求最小值 、count(字段名、*) :统计行数 ----、按部门编号,查询平均薪水 ,并且平均薪水<1300的不显示,结果按降序排序
select empno,avg(sal) as avgsal
from scott.emp
group by empno
having avg(sal)>=
order by avgsal desc; 说明:
SQL语句的执行顺序:一定是从上到下的! group by 执行之后才会执行having 、select中没有使用聚合函数的字段名必须写在这里 having 后不能使用字段的别名 可以聚合函数、一般字段名 order by 后面可以有:字段名、聚合函数、字段别名 注意:
Oracle 10g中才会出现的容错性: having 语句可以写在group by 之前,不会报错,但是实际上执行的顺序还是先执行group by 后执行having子句 说明:
、当一个查询中,出现聚合函数和没有使用聚合函数的字段,则该字段必须出现在group by子句中! 、group by 字段1,字段2; 会先按照字段1分组得到一个结果集,再按照字段2进行分组! 、where 发生在group by 前! 、where 后面不能有聚合函数! 多表查询: 表连接分类: 内连接、外连接、交叉连接 、内连接: [inner] join on SQL语法格式:
语法1:
select *
from 表1 [inner] join 表2 on 表1.字段1=表2.字段1; 语法2:
select *
from 表1,表2
where 表1.字段1=表2.字段1; 说明:
内连接中的inner join 和 join 是等价的!但是建议为了程序的可读性 尽量不要省略inner! 、外连接: 分类:左外连接、右外连接、全连接! 、左外连接:left outer join 连接效果:
左侧的表中的全部数据都会被显示出来,但是右侧表的数据,
只有和左侧匹配上的字段才会被查询出来!否则都会显示null! SQL语法格式: 语法1:
select *
from 表1 left outer join 表2
on 表1.字段1=表2.字段1; 语法2:
select *
from 表1 left outer join 表2
where 表1.字段1=表2.字段1(+); 、右外连接:right outer join 连接效果:
右侧的表中的全部数据都会被显示出来,但是左侧表的数据,
只有和右侧匹配上的字段才会被查询出来!否则都会显示null! SQL语法格式: 语法1:
select *
from 表1 right outer join 表2
on 表1.字段1=表2.字段1; 语法2:
select *
from 表1 left outer join 表2
where 表1.字段1(+)=表2.字段1; 、全外连接:full/all outer join SQL语法格式: select *
from 表1 full outer join 表2
on 表1.字段1=表2.字段1; 、交叉连接: 表与表之间做笛卡尔积查询! SQL语法格式:(无条件查询) select *
from 表1 cross join 表2; 或者 select *
from 表1, 表2;

数据库(学习整理)----7--Oracle多表查询,三种join连接的更多相关文章

  1. MySQL基础(三)多表查询(各种join连接详解)

    Mysql 多表查询详解 一.前言 二.示例 三.注意事项 一.前言 上篇讲到Mysql中关键字执行的顺序,只涉及了一张表:实际应用大部分情况下,查询语句都会涉及到多张表格 : 1.1 多表连接有哪些 ...

  2. Oracle单表备份三种方案

    备份方案一: 1. 备份 create table [备份名] as select * from [表名]; 2. 恢复 truncate table org_group; insert into o ...

  3. oracle系统表查询

    oracle查询用户下的所有表 select * from all_tab_comments -- 查询所有用户的表,视图等select * from user_tab_comments -- 查询本 ...

  4. Oracle锁表查询和解锁方法

    数据库操作语句的分类 DDL:数据库模式定义语言,关键字:create DML:数据操纵语言,关键字:Insert.delete.update DCL:数据库控制语言 ,关键字:grant.remov ...

  5. oracle锁表查询

    ORACLE EBS操作某一个FORM界面,或者后台数据库操作某一个表时发现一直出于"假死"状态,可能是该表被某一用户锁定,导致其他用户无法继续操作 复制代码代码如下: --锁表查 ...

  6. oracle 字典表查询

    1.oracle 字典表查询 /*显示当前用户*/ show user 在sql plus中可用,在pl sql中不可用 /*查看所有用户名*/ select username,user_id,cre ...

  7. 数据库开发-Django ORM的单表查询

    数据库开发-Django ORM的单表查询 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查询集 1>.查询集相关概述 查询会返回结果的集,它是django.db.mod ...

  8. Oracle 多表查询、查询运算符和集合运算

    一.多表查询 1.内连接 一般使用INNER JOIN关键字指定内连接,INNER可以省略,默认表示内连接.查询结果中只包含两表的公共字段值相等的行,列可以是两表中的任意列 2.外连接 包括左外连接. ...

  9. MySQL之多表查询一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习

    MySQL之多表查询 阅读目录 一 介绍 二 多表连接查询 三 符合条件连接查询 四 子查询 五 综合练习 一 介绍 本节主题 多表连接查询 复合条件连接查询 子查询 首先说一下,我们写项目一般都会建 ...

随机推荐

  1. linux之cut用法

    转载:http://www.cnblogs.com/dong008259/archive/2011/12/09/2282679.html cut是一个选取命令,就是将一段数据经过分析,取出我们想要的. ...

  2. glsl-UBO

    UBO 是什么?为何要用UBO? 1.数据共享设计 采用Block的原因是: 如果你的程序中包含了多个着色器,而且这些着色器使用了相同的Uniform变量,你就不得不为每个着色器分别管理这些变量.Un ...

  3. [SAM4N学习笔记]LED点灯程序

    一.准备工作:      将上一节搭建的工程模板复制一份,命名为"1.blink",这作为我们开发的第一个程序. 二.程序编写:      板子上只有一个可控制的LED,就是LED ...

  4. [经典] atoi && itoa

    atoi原型:int atoi(const char *nptr) atoi,需要考虑的内容: 1. 第一个字符为"-"时为负,系数为-1:为"+"时为正,系数 ...

  5. 多IDC数据分布--MySQL多机房部署 - 学习笔记 - 51CTO技术博客

    多IDC数据分布--MySQL多机房部署 - 学习笔记 - 51CTO技术博客 多IDC数据分布--MySQL多机房部署

  6. linux diff详解

    diff是Unix系统的一个很重要的工具程序. 它用来比较两个文本文件的差异,是代码版本管理的基石之一.你在命令行下,输入: $ diff <变动前的文件> <变动后的文件> ...

  7. 命令 "sudo -H" 中的这个 "H" 什么作用?

    脚本中使用$HOME变量 问题描述:某些同事原来写的脚本中包含如下内容. BIN_DIR=${HOME}/tools TAIR_BIN_DIR=${HOME}/tair_bin TAIR_SRC_DI ...

  8. Genymotion常见问题汇总(转)

    为什么说是常见问题整合呢,因为我就是Genymotion最悲剧的使用者,该见过的问题,我基本都见过了,在此总结出这血的教训,望大家不要重蹈覆辙.     常见问题1:Genymotion在开启模拟器时 ...

  9. thymelef 布局 fragment

    需求:布局页面, 把首页分成四个页面: header  footer ,content ,aside ,从githua 下载的原型, 所有内容是在一起的,这里拆分, 重用, 减少代码量 做法: 新建页 ...

  10. 20169210《Linux内核原理与分析》第九周作业

    第一部分:实验 首先还是网易云课堂的学习,这次的课程是可执行程序的装载. 预处理.编译和链接: 可执行程序是怎么来的 以c语言代码为例的话,经过预处理,编译成汇编代码,再汇编成目标码再链接可执行文件. ...