--复杂查询练习

-- 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. linux, configure --prefix 的作用

    指定安装路径不指定prefix,则可执行文件默认放在/usr /local/bin,库文件默认放在/usr/local/lib,配置文件默认放在/usr/local/etc.其它的资源文件放在/usr ...

  2. Daily Scrumming 2015.10.21(Day 2)

    今明两天任务表 Member Today’s Task Tomorrow’s Task 江昊 配置ruby与rails环境 配置mysql与数据库用户管理 配置apache2环境 学习rails Ac ...

  3. java 实验1

    北京电子科技学院(BESTI) 实     验    报     告 课程:Java程序设计 班级:1352 姓名:杨光 学号:20135233 成绩:            指导教师:娄嘉鹏  实验 ...

  4. An internal error occurred during: "Launching MVC on Tomcat 7.x".

    删除工作空间下的“/.metadata/.plugins/org.eclipse.core.runtime/.settings/com.genuitec.eclipse.ast.deploy.core ...

  5. Leetcode题库——7.反转整数

    @author: ZZQ @software: PyCharm @file: IntReverse.py @time: 2018/9/16 16:36 要求:整数反转(给定一个 32 位有符号整数,将 ...

  6. BNUOJ 52308 We don't wanna work! set模拟

    题目链接: https://acm.bnu.edu.cn/v3/problem_show.php?pid=52308 We don't wanna work! Time Limit: 60000msM ...

  7. json反序列化对象

    这个是同事研究的wcf中中根据type类型反序列化json的示例 /// <summary> /// json转对象 /// </summary> /// <param ...

  8. OSI协议和TCP/IP协议笔记

    1.OSI协议: 第7层应用层:OSI中的最高层.是用户与网络的接口.该层通过应用程序来完成网络用户的应用需求,如文件传输.收发电子邮件等.在此常见的协议有:HTTP,HTTPS,FTP,TELNET ...

  9. angularJS1笔记-(15)-自定义指令(accordion伸缩菜单原始实现)

    index.html: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...

  10. React---点击按钮实现内容复制功能

    思路: 1.给要复制的内容容器添加一个标签(可以是ID,可以是类名等),通过dom技术获取该容器对象: 2.创建Range对象(某个区域内连续的内容),把该容器对象放进去: 3.将Range对象添加到 ...