SQL复杂语句查询练习
--复杂查询练习
-- 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复杂语句查询练习的更多相关文章
- sql语句查询
1. sql语句查询某位数字或者某几位数字开头的数据,字段类型为数字类: %’: 2. sql搜索以4开头和含有李字的数据: select * from wlzbpre_user where real ...
- phpcmsv9自定义sql语句查询模型实现
在phpcmsv9中,自定义sql语句查询可不太好实现,传入sql语句查询很容易被内部转入生成一系列莫名其妙的sql语句,比如最佳前缀等等,直接造成sql语句查询错误,在此也提供两种解决办法,1修改底 ...
- 怎样用SQL语句查询一个数据库中的所有表?
怎样用SQL语句查询一个数据库中的所有表? --读取库中的所有表名 select name from sysobjects where xtype='u'--读取指定表的所有列名select nam ...
- SQL语句查询某表的所有字段及数据类型
SQL语句查询某表的所有字段及数据类型 SELECT name AS column_name , TYPE_NAME(system_type_id) AS column_type , max_leng ...
- sql语句查询数据库表结构信息
开发中经常用到查询指定表及其字段的信息,以下是我整理的SQL语句查询方法,供自己平时使用也提供给大家参考! 1.适用MS SQL SERVER: SELECT 表名 = then d.name els ...
- 如何用SQL语句查询Excel数据?
如何用SQL语句查询Excel数据?Q:如何用SQL语句查询Excel数据? A:下列语句可在SQL SERVER中查询Excel工作表中的数据. 2007和2010版本: SELECT*FROMOp ...
- 怎么用sql语句查询一个数据库有多少张表
今天在技术群中闲谈时忽然聊到一个问题,那就是当一个数据库中有多张表时怎么快速的获取到表的个数,从而给问询者一个准确的回答. 大家或许会说,这个问题和我们的数据库操作没有太大关系或者不是很挂钩,所以没意 ...
- 使用sql语句查询日期在一定时间内的数据
使用sql语句查询日期在一周内的数据 select * from ShopOrder where datediff(week,ordTime,getdate()-1)=0 //查询当天日期在一周年 ...
- Mybatis SQL语句查询
MyBatis中使用in查询时的注意事项 foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合. foreach一共有三种类型,分别为List,[](array),Map三种. ...
随机推荐
- linux, configure --prefix 的作用
指定安装路径不指定prefix,则可执行文件默认放在/usr /local/bin,库文件默认放在/usr/local/lib,配置文件默认放在/usr/local/etc.其它的资源文件放在/usr ...
- Daily Scrumming 2015.10.21(Day 2)
今明两天任务表 Member Today’s Task Tomorrow’s Task 江昊 配置ruby与rails环境 配置mysql与数据库用户管理 配置apache2环境 学习rails Ac ...
- java 实验1
北京电子科技学院(BESTI) 实 验 报 告 课程:Java程序设计 班级:1352 姓名:杨光 学号:20135233 成绩: 指导教师:娄嘉鹏 实验 ...
- An internal error occurred during: "Launching MVC on Tomcat 7.x".
删除工作空间下的“/.metadata/.plugins/org.eclipse.core.runtime/.settings/com.genuitec.eclipse.ast.deploy.core ...
- Leetcode题库——7.反转整数
@author: ZZQ @software: PyCharm @file: IntReverse.py @time: 2018/9/16 16:36 要求:整数反转(给定一个 32 位有符号整数,将 ...
- 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 ...
- json反序列化对象
这个是同事研究的wcf中中根据type类型反序列化json的示例 /// <summary> /// json转对象 /// </summary> /// <param ...
- OSI协议和TCP/IP协议笔记
1.OSI协议: 第7层应用层:OSI中的最高层.是用户与网络的接口.该层通过应用程序来完成网络用户的应用需求,如文件传输.收发电子邮件等.在此常见的协议有:HTTP,HTTPS,FTP,TELNET ...
- angularJS1笔记-(15)-自定义指令(accordion伸缩菜单原始实现)
index.html: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...
- React---点击按钮实现内容复制功能
思路: 1.给要复制的内容容器添加一个标签(可以是ID,可以是类名等),通过dom技术获取该容器对象: 2.创建Range对象(某个区域内连续的内容),把该容器对象放进去: 3.将Range对象添加到 ...