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;

左外连接和右外连接在这里提到,后面会详细讲解。

时间: 2024-10-11 15:07:16

oracle入门之对表数据查询(二)的相关文章

oracle入门之对表数据查询(三)

oracle表复杂查询--子查询 什么是子查询? 子查询是指嵌入在其它sql语句中的select语句,也叫嵌套查询. 单行子查询 单行子查询是指只返回一行数据的子查询语句. 请思考:如果显示与smith同一部门的所有员工? SQL>select * from emp where deptno=(select deptno from emp where ename='SMITH'); 将SMITH排除在外不显示 SQL>select * from emp where deptno=(select

oracle入门之对表数据查询(一)

此文中用到的表是Scott用户中自带的三张表: 基本select语句 基本语法: select [distinct] *|{columnl,column2,column3..} from table [where {condition}]; select [是否剔除重复数据] *|{字段名(列名),字段名2(列名2),字段名3(列名3)..} from 表名 [where {条件}];注意事项: 1.select指定查询哪些列的数据: 2.column指定列名: 3.*代表查询所有列: 4.fr

oracle数据库使用之数据查询入门

1.在查询过程中使用算术表达式对数据进行运算 student表结构例如以下: 最后一项salary表示每一个人的月薪,我如今想查询每一个人的年薪: 2.使用nvl函数处理null值.向表中插入一条数据,该数据的salary项为null: 不使用nvl函数: 使用nvl函数: 3.将查询结果的字符串连接起来: 这里我们使用oracle安装好之后scott用户自带的emp表: 4.查找1982年1月23日后入职的员工,下面几种方式都能够.注意日期的不同写法: 5.查询工资大于等于2000而且小于等于

Oracle入门之对表内容的dml操作

oracle表的管理--添加数据 使用insert语句向表中插入数据 插入数据基本语法: insert into table[(column [,column...])] values(value [,value...]); insert into 表名[(列名 [,列名2...])] values(值 [,值2...]); 注意事项: 1.插入的数据应与字段的数据类型相同. 2.数据的大小应在列的规定范围内,例如:不能将一个长度为80的字符串加入到长度为40的列中. 3.在values中列出的

visual studio 2013连接Oracle 11g并获取数据:(二:实现)

1.VS中新建一个winform窗体 (1)一个按钮 (2)一个数据表格视图(在里面显示得到的数据表) 2.双击按钮进入代码 (1)添加 using System.Data.OracleClient; 若提示找不到Oracle,工具箱里默认没有,工具箱--右键--选择项--.NET Framework组件 我把带Oracle字段的全添加到工具箱, (2)自动弹出了“数据适配器配置向导“,就是配置你的数据库连接的属性, 最后这个还不知道是什么意思,我就写了一个select语句,和在按钮事件代码中的

oracle入门(8)——实战:支持可变参数、多种条件、多个参数排序、分页的存储过程查询组件

[本文介绍] 学了好几天,由于项目需要,忙活了两天,写出了个小组件,不过现在还只能支持单表操作.也没考虑算法上的优化,查询速度要比hibernate只快了一点点,可能是不涉及多表查询的缘故吧,多表的情况下才更快. 经非专业的测试,在有分页的情况下,在300万条数据里面查询的时间保持在0.1秒内.相同查询条件+分页的情况下,hibernate 用时0.3秒内. 不分页的条件下,查出来的数据越多,时间越长,时间长的话,跟hibernate相相比就没什么优势了. [思路] 我的思路是从java传来”字

Oracle EBS-SQL (MRP-7):检查MRP计划运行报错原因之超大数据查询2.sql

The following scripts can be used to check for huge line numbers: -- PO Requisitions select * from PO_REQUISITION_LINES_ALL where LINE_NUM > 1000000000; -- PO Lines select * from PO_LINES_ALL where LINE_NUM > 1000000000; -- Receiving Supply SELECT *

数据库基本操作(二)--数据查询

//数据查询 create database JXGL; //创建数据库 use JXGL;//使用数据库 create table S( Sno char(10) not null unique, Sname char(20) not null unique, Ssex char(2), Sage int, Sdept char(20)); create table C( Cno char(2) not  null primary key (Cno), Cname char(20), Teac

SQL语句汇总(二)——数据修改、数据查询

首先创建一张表如下,创建表的方法在上篇介绍过了,这里就不再赘述. 添加新数据: INSERT INTO <表名> (<列名列表>) VALUES (<值列表>)  如: INSERT INTO t_student (student_id,student_name,student_age,student_sex) VALUES (1,'大毛',18,'男'); 其中列名可以省略,省略之后要求插入的值必须与列一一对应: INSERT INTO t_student VALUE