oracle入门之对表数据查询(二)
oracle表复杂查询
在实际应用中经常需要执行复杂的数据统计,经常需要显示多张表的数据,现在我们给大家介绍较为复杂的select语句
数据分组-max,min,avg,sum,count
如何显示所有员工中最高工资和最低工资
SQL>select max(sal) "最高工资",min(sal) "最低工资" from emp;
请查询最高年工资
SQL>select max(sal*13+nvl(comm,0)*13) "最高年工资",min(sal*13+nvl(comm,0)*13) "最低年工资" from emp;
显示所有员工的平均工资和工资总和
SQL>select avg(sal) "平均工资",sum(sal) "工资总和" from emp;
特别注意:avg(sal)不会把sal为null的行进行统计,因此我们要注意,如果,你希望为空值也考虑,则我们可以这样做
SQL>selec sum(sal)/count(*) from emp;
计算共有多少员工
SQL>select count(*) "共有员工" from emp;
扩展要求:
请显示工资最高的员工的名字,工作岗位
SQL>select ename,job from emp where sal=(select max(sal) from emp);
特别注意:select语句执行的顺序是从右向左执行,正好和书写的方式相反。
SQL>select ename,job from emp where sal=(select max(sal) from emp);
oracle会先执行select max(sal) from emp这个语句,得出最大工资后。再执行where条件前的语句。
请显示工资高于平均工资的员工信息
SQL>select * from emp where sal>(select avg(sal) from emp);
SQL>select * from emp where sal>(select sum(sal)/count(*) from emp);
oracle表复杂查询
group by和having子句
group by用于对查询的结果分组统计;
having子句用于限制(过滤)分组显示结果。
如何显示每个部门的平均工资和最高工资
SQL>select avg(sal) "平均工资",max(sal) "最高工资",deptno "部门编号" from emp group by deptno;
显示每个部门的每种岗位的平均工资和最低工资
SQL>select avg(sal) "平均工资",min(sal) "最低工资",job "职位",deptno "部门编号" from emp group by deptno,job order by deptno;
显示部门平均工资低于2000的部门号和它的平均工资
SQL>select avg(sal) "平均工资",deptno "部门编号" from emp group by deptno having avg(sal)<2000;
对数据分组的总结:
1、分组函数(avg...)只能出现在选择列表、having、order by子句中;
2、如果在select语句中同时包含有group by/having/order by那么他们的顺序是group by/having/order by;
3、在选择列中如果有列、表达式和分组函数,那么这些列和表达式必需有一个出现在group by子句中,否则会出错。
如select deptno,avg(sal),max(sal) from emp group by deptno having avg(sal)<2000;
这里deptno就一定要出现在group by 中。
oracle表复杂查询--多表查询
说明:
多表查询是指基于两个和两个以上的表或是视图的查询,在实际应用中,查询单个表可能不能满足你的需求,(如显示sales部门位置和其员工的姓名),这种情况下需要使用到(dept表和emp表)
显示雇员名,雇员工资及所在的部门的名字[笛卡尔集]
规定:多表查询的条件是至少不能少于表的个数-1
注意:笛卡尔集,在多表查询的时候,如果不带任何条件,则会出现笛卡尔集,避免笛卡尔集多表查询的条件是,至少不能少于表的个数-1
SQL>select e.ename,e.sal,d.dname from emp e,dept d where d.deptno=e.deptno;
如何显示部门为10的部门名、员工名和工资
SQL>select d.dname,e.ename,e.sal,e.deptno from emp e,dept d where d.deptno=e.deptno and e.deptno=10;
显示各个员工的姓名、工资及其工资的级别
SQL>select e.ename,e.sal,s.grade from emp e,salgrade s where e.sal between s.losal and s.hisal;
注意:在多表查询时,不同的表中列名相同时要加表名,不同时可不加。(为增强可读性,建议都加表名或别名)
扩展要求:
显示雇员名,雇员工资及所在部门的名字,并按部门排序。
SQL>select e.ename,e.sal,d.dname from emp e,dept d where e.deptno=d.deptno order by d.dname;
oracle表复杂查询--多表查询
自连接
自连接是指在同一张表的连接查询
显示员工的上级领导的姓名
SQL>select e2.ename from emp e1,emp e2 where e1.mgr=e2.empno;
比如显示'FORD'的上级
SQL>select e1.ename "员工姓名",e2.ename "领导姓名" from emp e1,emp e2 where e1.mgr=e2.empno and e1.ename='FORD';
扩展要求:
显示各员工的姓名和他的上级领导姓名
SQL>select e1.ename "员工姓名",e2.ename "领导姓名" from emp e1,emp e2 where e1.mgr=e2.empno;
疑惑:这里我们看到king没有显示,因为king没有上级。如果我们希望把没有上级的员工也显示出来,则需要使用到外连接。外连接包括左外连接和右外连接。此处提到外连接,后面会详细讲解。
左外连接:select 列名,.. from 表名1 left join 表名2 on 条件;
SQL>select e1.ename "员工姓名",e2.ename "直接上级领导" from emp e1 left join emp e2 on e1.mgr=e2.empno;
或者使用(+)在右边也可以实现左外连接。
SQL>select e1.ename "员工姓名",e2.ename "领导姓名" from emp e1,emp e2 where e1.mgr=e2.empno(+);
右外连接:select 列名,.. from 表名1 right join 表名2 on 条件;
SQL>select e1.ename "员工姓名",e2.ename "直接上级领导" from emp e2 right join emp e1 on e1.mgr=e2.empno;
或者使用(+)在左边也可以实现右外连接。
SQL>select e1.ename "员工姓名",e2.ename "领导姓名" from emp e1,emp e2 where e2.empno(+)=e1.mgr;
左外连接和右外连接在这里提到,后面会详细讲解。
oracle入门之对表数据查询(二)的更多相关文章
- oracle入门之对表数据查询(三)
oracle表复杂查询--子查询 什么是子查询? 子查询是指嵌入在其它sql语句中的select语句,也叫嵌套查询. 单行子查询 单行子查询是指只返回一行数据的子查询语句. 请思考:如果显示与smit ...
- oracle入门之对表数据查询(一)
此文中用到的表是Scott用户中自带的三张表: 基本select语句 基本语法: select [distinct] *|{columnl,column2,column3..} from table ...
- oracle数据库使用之数据查询入门
1.在查询过程中使用算术表达式对数据进行运算 student表结构如下: 最后一项salary表示每个人的月薪,我现在想查询每个人的年薪: 2.使用nvl函数处理null值,向表中插入一条数据,该数据 ...
- visual studio 2013连接Oracle 11g并获取数据:(二:实现)
1.VS中新建一个winform窗体 (1)一个按钮 (2)一个数据表格视图(在里面显示得到的数据表) 2.双击按钮进入代码 (1)添加 using System.Data.OracleClient; ...
- Oracle入门之对表内容的dml操作
oracle表的管理--添加数据 使用insert语句向表中插入数据 插入数据基本语法: insert into table[(column [,column...])] values(value [ ...
- Oracle 数据库基础:数据查询与操作
SELECT uname FROM TUser WHERE uname=‘admin’ SELECT 字段名列表 FROM 表名 WHERE 条件; 在Oracle数据库中,对象是属于模式的,每个账户 ...
- oracle数据库之多表查询二
多表查询解题思路: 1.分析题目要查询的结果涉及到那几张表 2.将每张表建立关联条件,否则会产生笛卡尔积 3.分清楚查询的条件,然后使用and将条件链接 4.涉及到分组查询的需要使用聚合函数 5.分组 ...
- Git.Framework 框架随手记--ORM查询数据集合 二
一. 分组查询 在SQL中使用Group By 来对数据分组,在实际中分组中一般与聚合函数一并使用.在Git.Framework中提供了相应的分组方法 DataTable Group(T entit ...
- Windows 7下通过Excel2007连接Oracle数据库并对表查询
http://blog.csdn.net/pan_tian/article/details/8133668 1. 环境变量的设置 1.1 ORACLE_HOME环境变量的设置,我这里指向了我的Ora ...
随机推荐
- 四、ConcurrentHashMap 锁分段机制
回顾: HashMap与Hashtable的底层都是哈希表,但是 HashMap:线程不安全 Hashtable:线程安全,但是效率非常低,且存在[复合操作](如"若存在则删除") ...
- 编译原理中DFA最小化
关于编译原理最小化的操作,专业术语请移步至:http://www.360doc.com/content/18/0601/21/11962419_758841916.shtml 这里只是记录一下个人的理 ...
- Map.putAll方法
import Java.util.HashMap; public class Map_putAllTest { public static void main(String[] args){ / ...
- ggplot的boxplot添加显著性 | Add P-values and Significance Levels to ggplots | 方差分析
参考:Add P-values and Significance Levels toggplots 多组比较,挑选感兴趣的显示显著性. data("ToothGrowth") he ...
- Batchnorm
Internal Covariate Shift:每一次参数迭代更新后,上一层网络的输出数据经过这一层网络计算后,数据的分布会发生变化,为下一层网络的学习带来困难(神经网络本来就是要学习数据的分布,要 ...
- ASP.NET MVC CSRF (XSRF) security
CSRF(Cross-site request forgery)跨站请求伪造,也被称为“One Click Attack”或者Session Riding,通常缩写为CSRF或者XSRF,是一种对网站 ...
- CF数据结构练习(二)
1. 833D Red-Black Cobweb 大意: 给定树, 边为黑色或白色, 求所有黑白边比例在$[\frac{1}{2},2]$内的路径边权乘积的乘积. 考虑点分治, 记黑边数为$a$, 白 ...
- Cookie、Session和自定义分页
一.cookie Cookie的由来 大家都知道HTTP协议是无状态的. 无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请求响应情况直接影响, ...
- React文档(二十二)context
React中,通过React组件可以很容易地追踪数据流.当你关注一个组件,你可以发现哪一个props被传递了,这样使得你的应用很容被推断. 在一些情况下,你想要传递数据通过组件树而不需要去手动在每一层 ...
- Genymotion下载及安装
引用https://blog.csdn.net/yht2004123/article/details/80146989 一.注册\登录 打开Genymotion官网,https://www.genym ...