表结构:
 create database MyCompany
 go
 use MyCompany
 go
 create table Departments
 (
     Department_ID ,) primary key,
     Department_Name ),
 )
 go
 create table Employees
 (
     Employee_Id ,) primary key,
     Employee_Name ),
     Employee_Job ),
     Salary money,
     Department_Id int foreign key references Departments(Department_ID)
 )
 Go

 --------------------------------------------插入数据----------------------------------------------------------------------------------
 ----------------------------------部门表-------------------------------------------------------------------
 SET IDENTITY_INSERT departments ON
              ,    N'财务部'                                                                                                                                                                                                                                                           )
              ,    N'行政部'                                                                                                                                                                                                                                                           )
              ,    N'开发部'                                                                                                                                                                                                                                                           )
              ,    N'市场部'                                                                                                                                                                                                                                                           )
 SET IDENTITY_INSERT departments OFF
 ------------------------=============================员工表================================================================================================
            ,    N             )
            ,    N             )
            ,    N             )
            ,    N             )
            ,    N             )
            ,    N             )
            ,    N             )
            ,    N             )
            ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )
           ,    N             )

 SET IDENTITY_INSERT employees OFF

上面是创建表和数据库的代码

use MyCompanyTest
go
select * from dbo.Departments
select * from Employees

--1.列出EMPLOYEES表中各部门的:部门编号,最高工资,
select e.department_Id 部门编号, MAX(e.Salary) 最高工资,MIN(e.salary)最低工资
from Employees e
group by e.department_Id 

--2.列出EMPLOYEES表中各部门的:部门编号、部门名称、最高工资、最低工资

  select 部门编号, 最高工资,最低工资 ,d.Department_Name from
      (select e.Department_ID 部门编号, max(e.Salary)最高工资,min(e.Salary)最低工资
     from Employees e
    group by e.Department_Id )as t join Departments d
on t.部门编号=d.Department_ID

--3.列出EMPLOYEES表中各部门中'职员'(Employee_job为'职员')的:最低工资,最高工资和部门Id

select min(Salary)最低工资,MAX(Salary) 最高工资,Department_Id 部门Id from Employees
where Employee_Job='职员'
group by Department_Id

--4.对于EMPLOYEES中最低工资小于1000的部门,列出EMPLOYEE_JOB为'职员'的:部门编号,最低工资,最高工资

select * from(
    select Department_Id,MIN(e.Salary)最低工资,MAX(e.Salary)最高工资  from Employees e
    where e.Employee_Job='职员'
    group by e.Department_Id) as t
    join Departments d on d.Department_ID =t.Department_Id

--5.根据部门编号由高到低,工资由低到高,列出每个员工的姓名,部门号,工资
        select * from Employees
        order by Department_Id desc , Salary asc
--6.列出'吴用'所在部门中每个员工的姓名与部门号
    select * from Employees where Department_Id in (
    select   Department_Id  from Employees where Employee_Name='吴用'
    )
--7.列出每个员工的姓名,头衔,部门号,部门名
    select e.Employee_Name,e.Employee_Job,d.Department_ID,d.Department_Name
     from Employees e join Departments d
    on e.Department_Id=d.Department_ID
--8.列出EMPLOYEES中头衔为'职员'的员工的姓名,工作,部门号,部门名

        select * from Employees e
        join Departments d on e.Department_Id=d.Department_ID
        where e.Employee_Job='职员'
--9.对于DEPARTMENTS表中,列出所有(说明是左联):部门名称,部门编号,以及该部门的:员工姓名与头衔
    select * from Departments d left join Employees e
    on d.Department_ID=e.Department_Id
--10.列出工资高于本部门工资平均水平的员工的部门编号,姓名,工资,并且按部门编号排序。
select * from Employees e join(
            select Department_Id, AVG(Salary)as 平均工资 from Employees  e
            group by e.Department_Id)as t --求出各个部门的平均工资
    on e.Department_Id=t.Department_Id
    where e.Salary > t.平均工资
    order by e.Department_Id

    ---相关子查询
    select * from employees as emp
    where
    exists(
     select department_id,avg(salary) as avg_salary
       from employees as emp_sub
        group by department_id
    having emp_sub.department_id=emp.department_id and emp.salary>avg(salary)
    )

----
select *
from EMPLOYEES as e
where
e.SALARY >(select avg(SALARY) from EMPLOYEES as b where e.DEPARTMENT_ID = b.DEPARTMENT_ID)
order by e.DEPARTMENT_ID
--11.对于EMPLOYEES,列出各个部门中工资高于本部门平均水平的员工 数和部门号,按部门号排序
select
        emp.department_id as 部门编号,
        count(*) as 员工数
from Employees as emp
where emp.salary >
        (select avg(salary) from employees  emp_sub
      where emp_sub.department_id=emp.department_id)
group by emp.department_id
order by emp.department_id

--12.请找出部门中具有2人以上,员工工资大于所在部门平均工资的:部门的id与这些人的人数。
--分解:
--1>.部门中有人的工资比部门的平均工资还高
--2>并且这些人在2人以上
--3>查询出这些部门Id,与工资高于部门平均工资的人的人数。
select
        emp.department_id as 部门编号,
        count(*) as 员工数
from Employees as emp
where emp.salary > (select avg(salary) from employees emp_sub where emp_sub.department_id=emp.department_id)
group by emp.department_id

order by emp.department_id

--13.对于EMPLOYEES中低于自己工资至少5人的员工,列出其部门号,姓名,工资,
--以及工资少于自己的人数
select

        employee_name 姓名,
        salary 工资,
        小于自己工资的人数=(select count(*) from employees as emp_sub where emp_sub.salary<emp.salary)
from employees as emp

sql习题练习的更多相关文章

  1. sql习题及答案

    sql习题:http://www.cnblogs.com/wupeiqi/articles/5729934.html 习题答案参考:https://www.cnblogs.com/wupeiqi/ar ...

  2. sql习题--转换(LEFT/RIGTH)

    /* 转换为100-5 0100-000051-998 0001-0099812-1589 0012-01589*/IF EXISTS(SELECT * FROM sys.objects WHERE ...

  3. SQL简单语句总结习题

    创建一个表记员工个人信息: --创建一个表 create table plspl_company_info( empno ) not null, ename ) not null, job ), ma ...

  4. 我认为测试应该掌握的SQL语句

    最近在学习Oracle,对测试人员而言必须掌握两种语言:第一种是DML,数据操纵语言 (Data Manipulation Language) 是SQL语言中,负责对数据库对象运行数据访问工作的指令集 ...

  5. 资料整理,SQL Server ,面试前复习笔记

    T-SQL 要掌握的知识点分类 SQL 面向数据库执行查询 SQL 从数据库取回数据 SQL 在数据库中插入新的记录 SQL 更新数据库中的数据 SQL 从数据库删除记录 SQL 创建新数据库 SQL ...

  6. 推荐《SQL基础教程(第2版)》中文PDF+源代码+习题答案

    我认为<SQL基础教程(第2版)>非常适合数据库学习的初学者.论述的角度是读者的角度,会换位思考到读者在看到这一段时候会发出怎样的疑问,非常难得:原始数据的例题只有一道,但是可以反复从不同 ...

  7. SQL Server(四)——查询练习(45道习题)

    题目:设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher). 四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1 ...

  8. Server SQL 2008 习题

    [序言:学期末了,整理了自己这个学期学习数据库做的练习题,也是让自己复习了一遍.有错误的话希望大佬能够批评指正,不胜感激] 一.修改数据库 (1)给db_temp数据库添加一个数据文件文件db_tem ...

  9. SQL Server(四)——查询练习(45道习题)转

    题目:设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher). 四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1 ...

随机推荐

  1. Eclipse中使用Maven创建Web时错误

    一.问题描述 使用Eclipse创建Maven项目时,报一下错误,不能创建成功. 二.问题原因 错误详细描述是说 Could not resolve archetype org.apache.mave ...

  2. [ CodeVS冲杯之路 ] P1010

    不充钱,你怎么AC? 题目:http://codevs.cn/problem/1010/ 首先我们将坐标都+1,因为它是从(0,0)开始的 预处理出禁区,也就是马能到达的格子和马自己的格子,标上记号 ...

  3. MFC CString GetBuffer/ReleaseBuffer 的使用条件

      今天为了通过串口往单片机里写一个16进制字符去控制单片机的adc的起停,结果糊涂到把'\x01'误写成'\0x01',怎么也得不到意想的结果,程序员有时候会犯低级错误,有时候怎么也跳不出去,这时候 ...

  4. tomcat 异常:Caused by: org.apache.catalina.LifecycleException: The connector cannot start since the specified port value of [-1] is invalid

    启动tomcat时出现异常: org.apache.catalina.LifecycleException: Failed to start component [Connector[AJP/1.3- ...

  5. UVA 1604:Cubic Eight-Puzzle(模拟,BFS Grade C)

    题意: 3*3方格,有一个是空的.其他的每个格子里有一个立方体.立方体最初上下白色,前后红色,左右蓝色.移动的方式为滚.给出初态空的位置,终态上面颜色情况,问最少多少步能到达.如果超过30步不能到达, ...

  6. RobotFramework自动化1-环境搭建【转载】

    本篇转自博客:上海-悠悠 原文地址:http://www.cnblogs.com/yoyoketang/tag/robotframework/ 前言 Robot Framework是一款python编 ...

  7. Android_html5交互 弹框localstorage 存值 整体案例

    经历2周多的时间 终于是完成了还算可以的android 整体案例了,分享下给大家  也希望自己有时间回过头来看看当初研究android的纠结心情.痛苦的经历是开发android 大部分都是在网上找解决 ...

  8. codeforces-723D

    题目连接:http://codeforces.com/contest/723/problem/D D. Lakes in Berland time limit per test 2 seconds m ...

  9. java Iterable

    Iterable

  10. POJ1655 Balancing Act(树的重心)

    树的重心即树上某结点,删除该结点后形成的森林中包含结点最多的树的结点数最少. 一个DFS就OK了.. #include<cstdio> #include<cstring> #i ...