Oracle常用sql语句(二)之组函数、多表查询
DML(数据操纵语言)#
INSERT 、UPDATE、 DELETE
插入操作:INSERT:
语法: INSERT INTO 表名(列名1,列名2 ...)VALUES(列值1,列值2...);
注意:列名与列值的类型、个数、顺序要一一对应。
可以把列名当做java中的形参,把列值当做实参。
值不要超出列定义的长度。
如果插入空值,请使用null
插入的日期和字符一样,都使用引号括起来。
修改操作 UPDATE:
语法:UPDATE 表名 SET 列名1=列值1,列名2=列值2 ........ WHERE 列名=值
删除操作 DELETE:
语法 : DELETE FROM 表名 【WHERE 列名=值】
注意:where语句可以不写
DELETE :删除表中的数据,表结构还在;删除后的数据可以找回。
TRUNCATE :删除是把表直接DROP掉,然后再创建一个同样的新表。
删除的数据不能找回。执行速度比DELETE快。
DQL(数据查询语言)
**查询表中的所有数据 **
语法: SELECT 列名 FROM表名
[WHERE --> GROUP BY -->HAVING--> ORDER BY]
语法:
SELECT selection_list /*要查询的列名称*/
FROM table_list /*要查询的表名称*/
WHERE condition /*行条件*/
GROUP BY grouping_columns /*对结果分组*/
HAVING condition /*分组后的行条件*/
ORDER BY sorting_columns /*对结果分组*/
LIMIT offset_start, row_count /*结果限定*/
DML是对表中的数据进行增、删、改的操作。不要与DDL(数据定义语言)混淆了。
查询代码的书写顺序和执行顺序
查询语句书写顺序:select – from- where- group by- having- order by-limit
查询语句执行顺序:from -> where --> group by --> having --> select --> order by --> limit
注:其中WHERE 语句执行顺序是从右到左
组函数(多行函数,分组函数)
注:组函数会自动忽略空值,NVL函数使分组函数无法忽略空值
AVG(expr) 求平均值
COUNT([DISTINCT] expr) 统计行数,当expr=*时,所有的行数,expr=COLUMN时会自动过滤对应列的空值的行数
DISTINCT 去掉重复行MAX(expr) 求最大值
MIN(expr) 求最小
SUM(expr) 求和
分组函数(GROUP BY)
注:SELECT 中的列不在组函数中就必须在 GROUP BY 中
多个列的分组:先按照第一个列分组,如果相同,再第二个列分组,依次类推
SELECT
deptno,
job,
AVG( sal )
FROM
emp
GROUP BY
deptno,
job;
Oracle的增强GROUP BY:用于做财务报表
**break on deptno skip 2 **
-- 部门号只显示一个,不同的部门号跳过2行break on null 关闭设置
GROUP BY ROLLUP(a,b) 增强分组
例子
SELECT
deptno,
job,
SUM( sal )
FROM
emp
GROUP BY
ROLLUP (
deptno,
job)
上面代码相当于下面几个分组函数的和
SELECT
deptno,
job,
SUM( sal )
FROM
emp
GROUP BY
deptno,
job;
+
SELECT
deptno,
SUM( sal )
FROM
emp
GROUP BY
deptno,
job;
+
SELECT
SUM( sal )
FROM
emp
GROUP BY
deptno,
job
即:
GROUP BY a,b + GROUP BY a + 没有GROUP BY
过滤分组(HAVING)
注:不能再WHERE子句中使用组函数
可以在HAVING 子句中使用组函数,尽量使用WHERE
SELECT
deptno,
job,
AVG( sal )
FROM
emp
GROUP BY
deptno,
job
HAVING AVG(sal)>300;
重点:HAVING 可以和组函数配合使用,不是必须和GROUP BY配合,例子如下
SELECT COUNT(*)
from dual
HAVING COUNT(*)>0;
多表查询
- 连接类型
- 等值连接
- 不等值连接
- 外连接
- 自连接
左外连接:当条件不成立的时候,等号左边的表依然包含在最后的结果中
写法:
WHERE e.deptno=d.deptno(+) 或者FROM emp e right outer join dept d on e.deptno=d.deptno
右外连接:当条件不成立的时候,等号右边的表依然包含在最后的结果中
写法:
WHERE e.deptno(+)=d.deptno 或者FROM emp e left outer join dept d on e.deptno=d.deptno
例子
按部门号查询部门号,部门名称,人数
SELECT d.deptno 部门号,d.dname 名称,COUNT(e.empno) 人数
FROM emp e ,dept d
WHERE e.deptno(+)=d.deptno
GROUP BY d.deptno,d.dname
SELECT d.deptno 部门号,d.dname 名称,COUNT(e.empno) 人数
FROM emp e right outer join dept d
on e.deptno=d.deptno
GROUP BY d.deptno,d.dname
自连接: 通过表的别名,将同一张表视为多张表
注:自连接不适合操作大表
-- 查询员工信息: 员工姓名 老板名
SELECT e1.empno,e1.ename 员工,e2.empno,e2.ename 老板
FROM emp e1 left outer join emp e2
on e1.mgr=e2.empno
SELECT e1.empno,e1.ename 员工,e2.empno,e2.ename 老板
FROM emp e1 , emp e2
WHERE e1.mgr=e2.empno(+)
层次查询
实质是单表查询
在层次查询中Oracle为我们提供了伪列 leval
上面的自连接问题:
查询员工信息: 员工姓名 老板名
SELECT LEVEL ,empno, ename,mgr
FROM emp
CONNECT BY PRIOR empno=mgr
START WITH mgr IS NULL;
Oracle常用sql语句(二)之组函数、多表查询的更多相关文章
- oracle常用SQL语句(汇总版)
Oracle数据库常用sql语句 ORACLE 常用的SQL语法和数据对象一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, ...
- oracle 常用sql语句
oracle 常用sql语句 1.查看表空间的名称及大小 select t.tablespace_name, round(sum(bytes/(1024*1024)),0) ts_sizefrom d ...
- 剑指Offer——常用SQL语句、存储过程和函数
剑指Offer--常用SQL语句.存储过程和函数 常用SQL语句 1.在MySQL数据库建立多对多的数据表关系 2.授权.取消授权 grant.revoke grant select, insert, ...
- Oracle常用SQL语句大全
常用Oracle数据库SQL语句汇总. 1.常用操作 --清空回收站purge recyclebin;--查询回收站select * from recyclebin--查询Oracle版本信息sele ...
- ysql常用sql语句(12)- group by 分组查询
测试必备的Mysql常用sql语句,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1683347.html 前言 ...
- Mysql常用sql语句(11)- between and 范围查询
测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 between and可以判断值是否在指定范围内 ...
- Mysql常用sql语句(19)- in / exists 子查询
测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 子查询在我们查询方法中是比较常用的,通过子查询可 ...
- Mysql常用sql语句(7)- order by 对查询结果进行排序
测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 通过select出来的结果集是按表中的顺序来排序 ...
- Mysql常用sql语句(10)- is null 空值查询
测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 is null是一个关键字来的,用于判断字段的值 ...
随机推荐
- 【bzoj2588】Count on a tree
Portal -->bzoj2588 Solution 不行我一定要来挂这道题qwq很气愤qwq(其实还不是因为自己蠢..) 额首先说一下正解 如果这个问题放在序列上面的话..直接离散化一下然后 ...
- CentOS 7网络故障
By francis_hao Nov 2,2017 在像往常一样打开了虚拟机后,打开xshell准备连接到centos,可是连不上,发现连接的网卡没有启动,使用systemctl启动netw ...
- Codeforces 938.C Constructing Tests
C. Constructing Tests time limit per test 1 second memory limit per test 256 megabytes input standar ...
- [线索二叉树] [LeetCode] 不需要栈或者别的辅助空间,完成二叉树的中序遍历。题:Recover Binary Search Tree,Binary Tree Inorder Traversal
既上篇关于二叉搜索树的文章后,这篇文章介绍一种针对二叉树的新的中序遍历方式,它的特点是不需要递归或者使用栈,而是纯粹使用循环的方式,完成中序遍历. 线索二叉树介绍 首先我们引入“线索二叉树”的概念: ...
- Ant Design 通过 WeekPicker 获取一周的起止时间
项目中遇到了选择日期获取当前日期一周的周一和周日的日期,如下: 项目使用的是 ant design,所以第一时间想到了 DatePicker 中的 WeekPicker 组件,查询文档得到 WeekP ...
- springsecurity basic 认证
Basic Access Authentication scheme是在HTTP1.0提出的认证方法,它是一种基于challenge/response的认证模式,针对特定的realm需要提供用户名和密 ...
- GYM 101128 G.Game of Cards(博弈论) 或者 UVALIVE 7278
题目链接:http://codeforces.com/gym/101128/my 如果可以,就看这个人的代码吧,我还不是很懂唉:http://blog.csdn.net/loy_184548/arti ...
- 使用HTML5、CSS3和jQuery增强网站用户体验[留存]
记得几年前如果你需要添加一些互动元素到你的网站中用来改善用户体验?是不是立刻就想到了flash实现?这彷佛年代久远的事了.使用现在最流行的Web技术HTML5,CSS3和jQuery,同样也可以实现类 ...
- 【SRM20】数学场
第一题 n个m位二进制,求异或值域总和. [题解]异或值域--->使用线性基,解决去重问题. m位二进制--->拆位,每位根据01数量可以用组合数快速统计总和. #include<c ...
- 【BZOJ】4756: [Usaco2017 Jan]Promotion Counting
[题意]带点权树,统计每个结点子树内点权比它大的结点数. [算法]线段树合并 [题解]对每个点建权值线段树(动态开点),DFS中将自身和儿子线段树合并后统计. 注意三个量tot,cnt,tots,细心 ...