Oracle入门第三天(上)——多表查询与分组函数
一、多表查询
所有的连接分析,参考之前随笔:http://www.cnblogs.com/jiangbei/p/7420136.html
1.笛卡尔积
select last_name, department_name
from employees, departments
产生无效的笛卡尔积可以通过where进行过滤
连接查询:

2.等值连接
select e.last_name, d.department_name
from employees e, departments d
where e.department_id = d.department_id
3.外连接
SQL99的连接语法如下:
SELECT table1.column, table2.column
FROM table1
[CROSS JOIN table2] |
[NATURAL JOIN table2] |
[JOIN table2 USING (column_name)] |
[JOIN table2
ON(table1.column_name = table2.column_name)] |
[LEFT|RIGHT|FULL OUTER JOIN table2
ON (table1.column_name = table2.column_name)];
,这里介绍Oracle的左外连接写法:
--左外连接(e left join d)
select e.last_name,e.department_id, d.department_name
from employees e,departments d
where e.department_id = d.department_id(+)
自然连接可以省略连接条件,自动匹配所有相同的行进行笛卡尔积去重!
--自然连接(此种形式下无法使用表别名)
select employees.last_name,employees.department_id, departments.department_name
from employees NATURAL JOIN departments
CROSS JOIN叉集——与笛卡尔积相同
--CROSS JOIN叉集
SELECT last_name, department_name
FROM employees
CROSS JOIN departments ;
自连接
--自连接
SELECT
e1.last_name,e2.last_name,e2.salary,e2.email
FROM
employees e1,employees e2
WHERE
e1.manager_id = e2.employee_id
AND
LOWER(e1.last_name) = 'chen'
二、分组函数
1.组类型函数
AVG 返回平均值
COUNT 返回记录的数量(非空数目)
COUNT(DISTINCT expr)返回expr非空且不重复的记录总数
MAX 返回最大值
MIN 返回最小值
SUM 返回总值
STDDEV 返回标准差
VARIANCE 返回统计方差
方差与标准差的拓展阅读:点击查看
示例:
SELECT AVG(salary),SUM(salary),MAX(salary),MIN(salary)
FROM employees
AVG(SALARY) SUM(SALARY) MAX(SALARY) MIN(SALARY)
----------- ----------- ----------- -----------
6461.682242 691400 24000 2100
2.分组——GROUP BY
查询列仅能是分组列或组函数(聚合函数)
SELECT department_id,ROUND(AVG(salary),2) sal_avg
FROM employees
GROUP BY department_id
DEPARTMENT_ID SAL_AVG
------------- ----------
100 8600
30 4150
7000
90 19333.33
20 9500
70 10000
110 10150
50 3475.56
80 8955.88
40 6500
60 5760
10 4400
与WHERE的搭配,注意SQL的顺序:(这里是先选出符合条件的,再进行分组,分组过滤则参考HAVING)
SQL顺序(手写顺序与机读顺序参考之前随笔:http://www.cnblogs.com/jiangbei/p/7420136.html)
SELECT department_id,ROUND(AVG(salary),2) sal_avg
FROM employees
WHERE department_id IN (10,20,30)
GROUP BY department_id
3.分组过滤HAVING
WHERE中不能使用组函数过滤,于是HAVING登场..
示例:
SELECT department_id,ROUND(AVG(salary),2) sal_avg
FROM employees
GROUP BY department_id
HAVING AVG(salary) > 7500
4.组函数支持嵌套
SELECT MAX(AVG(salary)) sal_avg
FROM employees
GROUP BY department_id
Oracle入门第三天(上)——多表查询与分组函数的更多相关文章
- Oracle总结【SQL细节、多表查询、分组查询、分页】
前言 在之前已经大概了解过Mysql数据库和学过相关的Oracle知识点,但是太久没用过Oracle了,就基本忘了...印象中就只有基本的SQL语句和相关一些概念....写下本博文的原因就是记载着Or ...
- oracle 10g 学习之多表查询、分组函数(6)
笛卡尔集 l 笛卡尔集会在下面条件下产生: 省略连接条件 连接条件无效 所有表中的所有行互相连接 l 为了避免笛卡尔集, 可以在 WHERE 加入有效的连接条件. 自连接 select m.las ...
- Oracle入门第三天(下)——子查询
一.子查询 1.子查询语法 SELECT select_list FROM table WHERE expr operator (SELECT select_list FROM table) 示例: ...
- jQuery入门第三
jQuery入门第三 1.HTML 2.CSS 衣服 3.javascript 可以动的人 4.DOM 编程 对html文档的节点操作 5.jQuery 对 javascript的封装 简练的语法 复 ...
- 第十七篇 ORM跨表查询和分组查询---二次剖析
ORM跨表查询和分组查询---二次剖析 阅读目录(Content) 创建表(建立模型) 基于对象的跨表查询 一对多查询(Publish与Book) 多对多查询 (Author 与 Book) 一对一查 ...
- ORM单表查询,跨表查询,分组查询
ORM单表查询,跨表查询,分组查询 单表查询之下划线 models.Tb1.objects.filter(id__lt=10, id__gt=1) # 获取id大于1 且 小于10的值models ...
- java入门第三步之数据库连接
数据库连接可以说是学习web最基础的部分,也是非常重要的一部分,今天我们就来介绍下数据库的连接为下面学习真正的web打下基础 java中连接数据库一般有两种方式: 1.ODBC——Open Datab ...
- java入门第三步之数据库连接【转】
数据库连接可以说是学习web最基础的部分,也是非常重要的一部分,今天我们就来介绍下数据库的连接为下面学习真正的web打下基础 java中连接数据库一般有两种方式: 1.ODBC——Open Datab ...
- HTML入门第三天
三. 表格table(表格类数据): 1.表格标签(重中之重) 基本结构标签: <table>:定义表格区域 <tr>:定义表格的行 <td>:定义表格中的单元格 ...
随机推荐
- oracle中RAW数据类型
近日在研究v$latch视图时,发现一个从未见过的数据类型.v$latch 中ADDR属性的数据类型为RAW(4|8) 同时也发现v$process中的ADDR属性的数据类型也为RAW(4|8).于 ...
- 51nod 1349 最大值
题目看这里 找到每个元素g[i]作为最大值的区间[L,R],那么以他为最大值的区间数有(i-L+1)*(R-i+1)个. 为了加速,以k为最大值的区间数放入H[k],再以此统计一个前缀和,更新入H.那 ...
- 【Try Kotlin】Kotlin Koans 代码笔记
Kotlin Koans 心印 Introduction 1.Hello, world! Simple Functions Take a look at function syntax and mak ...
- hook与链表操作
hook与链表的节点操作有相似之处: 链表的前后顺序相当于程序的执行流: 对链表节点的替换或插入相当于hook技术: 1.替换:用新的节点替换原来的节点: 2.前插入: 3.后插入: 修改原来的结构.
- CSS样式命名规则
1.样式命名外 套: wrap主导航: mainnav子导航: subnav页 脚: footer整个页面: content页 眉: header页 脚: footer商 标: label标 题: t ...
- 用Qt制作的Android独立游戏《吃药了》公布
一个多月的努力最终有了回报,我自己研究制作的独立游戏<吃药了>.最终在360应用商店上线了. 这一款游戏呢.使用的是Qt开发的.事实上开发这款简单的应用之前.我 ...
- ValueError: All strings must be XML compatible: Unicode or ASCII, no NULL bytes or control characters
转载请注明原文地址:https://www.cnblogs.com/cnodoo/p/9281366.html ValueError: All strings must be XML compati ...
- F、CSL 的神奇序列 【规律】 (“新智认知”杯上海高校程序设计竞赛暨第十七届上海大学程序设计春季联赛)
题目传送门:https://ac.nowcoder.com/acm/contest/551/F 题目描述 CSL 有一个神奇的无穷实数序列,他的每一项满足如下关系: 对于任意的正整数 n ,有 n∑k ...
- Js 中的 this
Js 中 this 的理解 this 是啥 ? this是 JavaScript 语言的一个关键字,它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用; 随着函数使用场合的不同,this ...
- [SCOI2005]互不侵犯(状压DP)
嗝~算是状压DP的经典题了~ #\(\mathcal{\color{red}{Description}}\) 在\(N×N\)的棋盘里面放\(K\)个国王,使他们互不攻击,共有多少种摆放方案.国王能攻 ...