--复杂查询练习

-- 1 、列出所有员工的年工资,按年薪从低到高排序。
SELECT (SAL+NVL(COMM,0))*12 INCOME FROM EMP ORDER BY INCOME;

-- 2 、列出薪金比“ SMITH ”多的所有员工。
--获取SMITH 的工资
SELECT * FROM EMP WHERE SAL >(SELECT SAL FROM EMP WHERE ENAME = 'SMITH');

-- 3 、列出所有员工的姓名及其直接上级的姓名。
SELECT E1.ENAME,E2.ENAME
FROM EMP E1
LEFT JOIN EMP E2
ON E1.MGR = E2.EMPNO;

-- 4 、列出受雇日期早于其直接上级的所有员工。
SELECT E1.ENAME,E1.HIREDATE,E2.ENAME,E2.HIREDATE
FROM EMP E1
LEFT JOIN EMP E2
ON E1.MGR = E2.EMPNO
WHERE E1.HIREDATE <E2.HIREDATE;

-- 5 、列出部门名称和这些部门的员工信息,包括那些没有员工的部门。
SELECT D.DNAME,E.EMPNO,E.ENAME,DEPTNO
FROM EMP E
RIGHT JOIN DEPT D
USING(DEPTNO);

-- 6 、列出所有job 为“ CLERK ”(办事员)的姓名及其部门名称。

--1.查询所有job为“CLERK”的姓名
SELECT D.DNAME,T.ENAME FROM
(SELECT DEPTNO,ENAME FROM EMP WHERE JOB ='CLERK') T,DEPT D
WHERE T.DEPTNO = D.DEPTNO;

-- 7 、列出最低工资大于1500 的各种工作。
SELECT JOB
FROM EMP
GROUP BY JOB
HAVING MIN(SAL)>1500;

-- 8 、列出在部门“ SALES ”(销售部)工作的员工的姓名,假定不知道销售部的部门编号。
--1.获取销售部的部门编号
SELECT ENAME,DEPTNO FROM EMP
WHERE DEPTNO = (SELECT DEPTNO FROM DEPT WHERE DNAME = 'SALES');

-- 9 、列出工资高于公司平均工资的所有员工。
--获取公司的平均工资
SELECT * FROM EMP WHERE SAL >(SELECT ROUND(AVG(SAL)) AVG_SAL FROM EMP);

-- 10 、列出与“ SCOTT ”从事相同工作的所有员工。
--获取SCOTT的工作
SELECT * FROM EMP WHERE JOB = (SELECT JOB FROM EMP WHERE ENAME = 'SCOTT')
AND ENAME <> 'SCOTT';

-- 11 、列出工资高于在部门 30 工作的所有员工的工资的员工姓名和工资。
--1.获取30号部门员工的工资
SELECT ENAME,SAL FROM EMP WHERE SAL >ALL(SELECT SAL FROM EMP WHERE DEPTNO = 30);

-- 12 、列出在每个部门工作的员工数量、平均工资和平均服务期限(年)。
SELECT COUNT(*),ROUND(AVG(SAL)) AVG_SAL,ROUND(AVG(TO_CHAR(SYSDATE,'YYYY')-TO_CHAR(HIREDATE,'YYYY'))) AVG_YEAR
FROM EMP
GROUP BY DEPTNO;

-- 13 、列出所有员工的姓名、部门名称和工资。
SELECT E.ENAME,D.DNAME,E.SAL
FROM EMP E NATURAL JOIN DEPT D;

-- 14 、列出从事同一种工作但属于不同部门的员工的一种组合。
--[自连接]
--E1 和 E2 都当成员工表

SELECT E1.ENAME,E1.JOB,E1.DEPTNO,E2.ENAME,E2.JOB,E2.DEPTNO
FROM EMP E1,EMP E2
WHERE E1.JOB = E2.JOB
AND E1.DEPTNO <> E2.DEPTNO
AND E1.ENAME<E2.ENAME;

-- 15 、列出所有部门的详细信息和部门人数(包含没有员工的部门)。
SELECT D.*,COUNT(E.EMPNO)
FROM EMP E RIGHT JOIN DEPT D
ON E.DEPTNO = D.DEPTNO
GROUP BY D.DEPTNO,D.DNAME,D.LOC;

-- 16 、列出各种工作的最低工资。
SELECT JOB,MIN(SAL)
FROM EMP
GROUP BY JOB;

-- 17 、列出各个部门的 MANAGER (经理)的最低薪金。
SELECT DEPTNO,MIN(SAL)
FROM EMP
WHERE JOB = 'MANAGER'
GROUP BY DEPTNO;

-- 18 、列出至少有一个员工的所有部门。
SELECT DEPTNO
FROM EMP
GROUP BY DEPTNO
HAVING COUNT(*)>=1;

SQL复杂语句查询练习的更多相关文章

  1. sql语句查询

    1. sql语句查询某位数字或者某几位数字开头的数据,字段类型为数字类: %’: 2. sql搜索以4开头和含有李字的数据: select * from wlzbpre_user where real ...

  2. phpcmsv9自定义sql语句查询模型实现

    在phpcmsv9中,自定义sql语句查询可不太好实现,传入sql语句查询很容易被内部转入生成一系列莫名其妙的sql语句,比如最佳前缀等等,直接造成sql语句查询错误,在此也提供两种解决办法,1修改底 ...

  3. 怎样用SQL语句查询一个数据库中的所有表?

    怎样用SQL语句查询一个数据库中的所有表?  --读取库中的所有表名 select name from sysobjects where xtype='u'--读取指定表的所有列名select nam ...

  4. SQL语句查询某表的所有字段及数据类型

    SQL语句查询某表的所有字段及数据类型 SELECT name AS column_name , TYPE_NAME(system_type_id) AS column_type , max_leng ...

  5. sql语句查询数据库表结构信息

    开发中经常用到查询指定表及其字段的信息,以下是我整理的SQL语句查询方法,供自己平时使用也提供给大家参考! 1.适用MS SQL SERVER: SELECT 表名 = then d.name els ...

  6. 如何用SQL语句查询Excel数据?

    如何用SQL语句查询Excel数据?Q:如何用SQL语句查询Excel数据? A:下列语句可在SQL SERVER中查询Excel工作表中的数据. 2007和2010版本: SELECT*FROMOp ...

  7. 怎么用sql语句查询一个数据库有多少张表

    今天在技术群中闲谈时忽然聊到一个问题,那就是当一个数据库中有多张表时怎么快速的获取到表的个数,从而给问询者一个准确的回答. 大家或许会说,这个问题和我们的数据库操作没有太大关系或者不是很挂钩,所以没意 ...

  8. 使用sql语句查询日期在一定时间内的数据

    使用sql语句查询日期在一周内的数据 select * from ShopOrder where datediff(week,ordTime,getdate()-1)=0   //查询当天日期在一周年 ...

  9. Mybatis SQL语句查询

    MyBatis中使用in查询时的注意事项 foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合. foreach一共有三种类型,分别为List,[](array),Map三种. ...

随机推荐

  1. 读书笔记之java编程思想2

    今天将第一章余下的部分读完了,余下部分讲解了java单继承的特点,单继承保证了所有的子类都有一个基类,这使得java所实现的垃圾回收器的实现变得简单了很多,单继承保证了所有的对象都具有一些功能,使得参 ...

  2. Struts2 核心流程

    1.Struts2架构图  这是Struts2官方站点提供的Struts 2 的整体结构.  执行流程图 2.Struts2部分类介绍  这部分从Struts2参考文档中翻译就可以了. ActionM ...

  3. spring--两个数据源模板

    <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-met ...

  4. 数据库SQL中Like的用法总结

    最先做项目多次用到LIKE语句,下面总结下经常用到了. 语法 match_expression [ NOT ] LIKE pattern [ ESCAPE escape_character ] 参数 ...

  5. Beta阶段敏捷冲刺③

    1.提供当天站立式会议照片一张. 每个人的工作 (有work item 的ID),并将其记录在码云项目管理中: 1.1昨天已完成的工作. 姓名 昨天已完成的工作 徐璐琳 完善设置界面的功能 祁泽文 研 ...

  6. GDI+缩放图片

    uses WinAPI.GDIPAPI, WinAPI.GDIPOBJ; var  Bitmap1: TGPBitmap;  Bitmap2: TBitmap;  Graphic: TGPGraphi ...

  7. MSSQL中IN是否用索引.....[转]

    作者:no_mIss 用MSSQL时间快一年了,数据量有时会相对比较多,所以经常要优化,也看过很多资料,但大都有一句:IN.NOT IN不用索引,今天发此贴希望能有人参与讨论,到底IN用不用索引,如果 ...

  8. python基础(二)条件判断、循环、格式化输出

    继续上一篇,今天主要总结一下条件判断.循环.格式化输出 一.条件判断 python中条件判断使用if else来判断,多分支的话使用if elif ... else,也就是如果怎么怎么样就怎么怎么样, ...

  9. Thread start()方法和run()方法的区别

    转自:http://www.cnblogs.com/skywang12345/p/3479083.html start():作用一个新的线程,新线程会执行相应的run()方法,start()不能被重复 ...

  10. vsftpd重启失败解决方法

    vsftpd dead,but subsys locked vsftpd已死,但是subsys被锁 关于VSFTPD服务器重启失败,研究了一晚上,当virtual_use_local_privs=ye ...