题目9:MySQL---------Department Top Three Salaries

The Employee table holds all employees. Every employee has an Id, and there is also a column for the department Id.

+----+-------+--------+--------------+
| Id | Name  | Salary | DepartmentId |
+----+-------+--------+--------------+
| 1  | Joe   | 70000  | 1            |
| 2  | Henry | 80000  | 2            |
| 3  | Sam   | 60000  | 2            |
| 4  | Max   | 90000  | 1            |
| 5  | Janet | 69000  | 1            |
| 6  | Randy | 85000  | 1            |
+----+-------+--------+--------------+

The Department table holds all departments of the company.

+----+----------+
| Id | Name     |
+----+----------+
| 1  | IT       |
| 2  | Sales    |
+----+----------+

Write a SQL query to find employees who earn the top three salaries in each of the department. For the above tables, your SQL query should return the following rows.

+------------+----------+--------+
| Department | Employee | Salary |
+------------+----------+--------+
| IT         | Max      | 90000  |
| IT         | Randy    | 85000  |
| IT         | Joe      | 70000  |
| Sales      | Henry    | 80000  |
| Sales      | Sam      | 60000  |
+------------+----------+--------+

create table Employee 
(
  Id int         NOT      NULL AUTO_INCREMENT,
  Name           char(10) null,
  Salary         int      null,
  DepartmentId   int      null,
  primary key (Id)
);

INSERT INTO Employee(Id ,Name,Salary,Departmentid) values(1,"Joe",70000,1);
INSERT INTO Employee(Id ,Name,Salary,Departmentid) values(2,"Henry",80000,2);
INSERT INTO Employee(Id ,Name,Salary,Departmentid) values(3,"Sam",60000,2);
INSERT INTO Employee(Id ,Name,Salary,Departmentid) values(4,"Max",9000,1);
INSERT INTO Employee(Id ,Name,Salary,Departmentid) values(5,"Janet",69000,1);
INSERT INTO Employee(Id ,Name,Salary,Departmentid) values(6,"Randy",85000,1);
create table Department
(
  Id    INT      NOT NULL auto_increment,
  Name  char(10) NULL,
  primary key (Id) 
);

insert into Department(Id, Name) values(1,"IT");
insert into Department(Id, Name) values(2,"Sales");

答案:

select D.Name as Department, E.Name as Employee, E.Salary as Salary 
  from Employee E, Department D
   where (select count(distinct(Salary)) from Employee 
           where DepartmentId = E.DepartmentId and Salary > E.Salary) in (0, 1, 2)
         and 
           E.DepartmentId = D.Id 
         order by E.DepartmentId, E.Salary DESC;










资源下载链接为: https://pan.quark.cn/s/9e7ef05254f8 PLC(可编程逻辑控制器)是现代工业自动化中不可或缺的控制设备,而梯形图(Ladder Diagram)作为其核心编程方式之一,是初学者必须掌握的基础梯形图是一种图形化编程语言,模拟电气控制线路,直观易懂,非常适合实现逻辑控制。以下是PLC编程初学者需要掌握的几个典型梯形图。 启动、保持、停止电路 这是PLC中最基本的控制逻辑,常用于电机的启动与停止。电路由一个常闭停止按钮、一个常开启动按钮和一个保持触点组成。按下启动按钮,电路闭合,电机运行;按下停止按钮,电路断开,电机停止。保持触点确保电机在启动后持续运行,直到收到停止信号。 三相异步电机正反转控制电路 在工业生产中,电机的正反转控制十分常见。梯形图中包含正转(Forward)和反转(Reverse)两个按钮。为了避免电机正反转同时发生,电路中加入了逻辑互锁机制:正转电路中包含反转停止信号,反之亦然,从而确保操作安全。 闪烁电路 闪烁电路用于控制灯光或信号的闪烁,通过PLC定时器实现。梯形图中通常使用一个辅助继电器和定时器。按下启动按钮后,定时器开始计时,辅助继电器触点在定时周期内交替动作,从而实现闪烁效果。 延时接通/断开电路 这种电路适用于需要延时响应的场合,例如电机启动后延时启动风扇。在梯形图中,通过定时器实现延时功能。当输入条件满足时,定时器开始计时,达到预设时间后输出信号才会改变。 DF上升沿微分和DFI下降沿微分 DF(上升沿微分)和DFI(下降沿微分)指令仅在输入信号的上升沿或下降沿瞬间触发输出,并维持一个扫描周期。这种指令适用于对输入信号的瞬间变化做出响应,例如触发计数器或进行状态信号的边缘检测。在某些PLC(如CX1-16R系列)中,DF和DFI指令的使用次数之和最多为128次。 自保持回路 自保持回路是PLC
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值