说明:表数据来自oracle 初始用户之一scott里面的三个初始表:emp,dept,salgrade

--1、查询员工表中工资最高的雇员的员工号、员工姓名、工资和部门号。

select empno,ename,sal,deptno from emp where sal=(select max(sal) from emp);

--2、薪水大于1200的雇员,按照部门编号进行分组,分组后平均薪水必须大于1500,查询各分组的平均水平,按照工资的倒序进行排列。

select deptno,avg(sal) from emp where sal>1200 group by deptno having avg(sal)>1500 order by avg(sal) desc;

--3、查询每个雇员和其所在部门名、按照员工名字排序,要求值显示第三条到第六条记录

--     rownum是伪列,rownum>2,没有查询到任何记录。
-- 因为rownum总是从1开始的,第一条不满足去掉的话,第二条的rownum 又成了1。依此类推,所以永远没有满足条件的记录。
-- 可以这样理解:rownum是一个序列,是Oracle数据库从数据文件或缓冲区中读取数据的顺序
select * from
(select emp.ename,dname,rownum rn from emp,dept where emp.deptno=dept.deptno and rownum<=6 order by emp.ename )--必须是内小于外大于
where rn>=3;
-- 内连接 只返回两个表中连接字段相等的行。
select ename,dname from emp inner join dept on emp.deptno = dept.deptno;
-- 第二种方式
select * from
(select emp.ename,dname,rownum rn from emp,dept where emp.deptno=dept.deptno order by emp.ename )
where rn between 3 and 6; -- 第三种
select * from(
select t.*, rownum rn from(
select ename,dname from emp inner join dept on emp.deptno = dept.deptno order by emp.ename
) t where rownum<=6
) where rn>=3;

-- 4、查询每个雇员姓名以及工资所在的等级。

--第一种
select ename,sal,grade from emp,salgrade where sal between losal and hisal; --第二种 内连接
select ename,sal,grade from emp inner join salgrade on sal between losal and hisal;

--5、查询雇员名第二个字母不是a的雇员的姓名、所在的组名、工资所在的等级

--第一种
--用substr分割截取字符串
select ename,dname,grade from emp,dept,salgrade
where sal between losal and hisal and emp.deptno=dept.deptno and substr(ename,2,1) !='a' and substr(ename,2,1) !='A'; --第二种
--内连接 模糊查询,第一个下划线代表第一个字符
select ename,dname,grade
from emp inner join dept on dept.deptno=emp.deptno
inner join salgrade on sal between losal and hisal
where ename not like '_A%';

--6、查询每个雇员和其经理的姓名

--第一种 使用自连接
select e1.ename empname,e2.ename mgrname from emp e1,emp e2
where e1.mgr=e2.empno;
--第二种 自连接与内连接
select e1.ename empname,e2.ename mgrname
from emp e1 inner join emp e2
on e1.mgr=e2.empno;

--7、查询每个雇员和其经理的姓名(包括公司老板本身(他上面没有经理));

--左连接,左表中所有记录()以及右表中连接字段相等的记录
select e1.ename empname,e2.ename mgrname from emp e1 left join emp e2 on e1.mgr=e2.empno;

--8、查询每个雇员的姓名及其所在部门的部门名(包括没有雇员的部门)

--右连接,油表中所有记录()以及右表中连接字段相等的记录
select ename,dname from emp right join dept on emp.deptno=dept.deptno;

--9、查询每个部门中工资最高的人的姓名、薪水和部门编号。

--把查询变成一个子表
--group by要包含所有选择的字段(除了函数的),所以先查询出每个部门最高工资,然后和原始表关联,就可以查出部门最高工资者的所有信息
select ename,sal,emp.deptno from emp
inner join
(select deptno,max(sal) msal from emp group by deptno) maxsalresult
on maxsalresult.deptno=emp.deptno and sal=maxsalresult.msal;

--10、查询每个部门平均工资所在的等级

select deptno,grade,avgsalresult.avgsal avragesal
from salgrade inner join
(select avg(sal) avgsal,deptno from emp group by deptno) avgsalresult
on avgsal between losal and hisal;

最新文章

  1. JAVA语言搭建白盒静态代码、黑盒网站插件式自动化安全审计平台
  2. php count()函数用法 及其 一个坑
  3. windows8.1下android开发环境搭建(Eclipse+Android sdk+ADT+Genymotion)
  4. div加边框
  5. encodeURI来解决URL传递时的中文问题
  6. Java语法糖4:内部类
  7. angular设置title
  8. 物料BOM和生产订单BOM的区别
  9. poj 3259 Wormholes
  10. The code of method _jspService(HttpServletRequest, HttpServletResponse) is exceeding the 65535 bytes limit
  11. 九度OJ 1516 调整数组顺序使奇数位于偶数前面 -- 归并排序
  12. mybatis03
  13. 小试牛刀——爬topit.me的图片,附github简易上传教程
  14. Java中boolean类型到底占用多少字节
  15. Elasticsearch 全教程--入门
  16. 【Algorithm】-NO.140.Algorithm.1.Algorithm.1.001-【空间复杂度 时间复杂度 o(1), o(n), o(logn), o(nlogn)】-
  17. Python机器学习笔记:深入学习Keras中Sequential模型及方法
  18. UE4的AI学习(1)——基本概念
  19. 使用Wisdom RESTClient如何在Linux和Mac上获取测试报告和API文档?
  20. hibernate添加数据报错:Could not execute JDBC batch update

热门文章

  1. OpenFOAM——高空腔内的湍流自然对流
  2. compile install deploy;
  3. 刷题记录:Shrine
  4. Oracle系列五 多表查询
  5. Gson字符串编码,字符串转换成图片保存,二进制转换成图片保存
  6. latex怎样生成table字样和caption换行的表格
  7. Pytorch 类别平衡化处理
  8. [LeetCode] 531. Lonely Pixel I 孤独的像素 I
  9. npm 私服工具verdaccio 搭建
  10. SpringBoot2+Druid+JdbcTemplate+MySql实现增删改查