SQL implementation of LeetCode (184. The highest salary in the department)

SQL implementation of LeetCode (184. The highest salary in the department)

[LeetCode] 184. Department Highest Salary

The Employee table holds all employees. Every employee has an Id, a salary, 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 |
+----+-------+--------+--------------+

The Department table holds all departments of the company.

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

Write a SQL query to find employees who have the highest salary in each of the departments. For the above tables, Max has the highest salary in the IT department and Henry has the highest salary in the Sales department.

+------------+----------+--------+
| Department | Employee | Salary |
+------------+----------+--------+
| IT | Max | 90000 |
| Sales | Henry | 80000 |
+------------+----------+--------+

This question gives us two tables, Employee and Department, and asks us to find the person with the highest salary in the department. In fact, this question is a combination of Second Highest Salary and Combine Two Tables . We need to combine the two tables and find the highest salary. So we first intersect the two tables, then mark the required columns in the result table, and then find the highest salary. We use the Max keyword to achieve this. See the code below:

Solution 1:

SELECT d.Name AS Department, e1.Name AS Employee, e1.Salary FROM Employee e1
JOIN Department d ON e1.DepartmentId = d.Id WHERE Salary IN 
(SELECT MAX(Salary) FROM Employee e2 WHERE e1.DepartmentId = e2.DepartmentId);

We can also use Where to join the two tables without using the Join keyword, and then find the highest salary in the same way as above:

Solution 2:

SELECT d.Name AS Department, e.Name AS Employee, e.Salary FROM Employee e, Department d
WHERE e.DepartmentId = d.Id AND e.Salary = (SELECT MAX(Salary) FROM Employee e2 WHERE e2.DepartmentId = d.Id);

The following method does not use the Max keyword, but uses the >= symbol, which achieves the same effect as the Max keyword. See the code below:

Solution 3:

SELECT d.Name AS Department, e.Name AS Employee, e.Salary FROM Employee e, Department d
WHERE e.DepartmentId = d.Id AND e.Salary >= ALL (SELECT Salary FROM Employee e2 WHERE e2.DepartmentId = d.Id);

Similar topics:

Second Highest Salary

Combine Two Tables

This is the end of this article about SQL implementation of LeetCode (184. The highest salary in the department). For more relevant content about SQL implementation of the highest salary in the department, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • SQL implementation of LeetCode (196. Delete duplicate mailboxes)
  • SQL implementation LeetCode (185. Top three highest salaries in the department)
  • SQL implementation of LeetCode (183. Customers who have never placed an order)
  • SQL implementation of LeetCode (182. Duplicate mailboxes)
  • SQL implementation of LeetCode (181. Employees earn more than managers)
  • SQL implements LeetCode (180. Continuous numbers)
  • C++ implementation of LeetCode (179. Maximum number of combinations)
  • SQL implementation of LeetCode (197. Rising temperature)

<<:  How to match the size of text in web design: small text, big experience

>>:  Website background music implementation method

Recommend

Detailed steps to use Redis in Docker

1. Introduction This article will show you how to...

Detailed deployment of Alibaba Cloud Server (graphic tutorial)

I have recently learned web development front-end...

Circular progress bar implemented with CSS

Achieve results Implementation Code html <div ...

How to automatically number the results of MYSQL query data

Preface In fact, I have never encountered this ki...

MySQL select, insert, update batch operation statement code examples

In projects, batch operation statements are often...

vue-router history mode server-side configuration process record

history route History mode refers to the mode of ...

Implementation steps for installing Redis container in Docker

Table of contents Install Redis on Docker 1. Find...

The difference between html, xhtml and xml

Development Trends: html (Hypertext Markup Languag...

CentOS 8.0.1905 installs ZABBIX 4.4 version (verified)

Zabbix Server Environment Platform Version: ZABBI...

How to mount a disk in Linux

When using a virtual machine, you may find that t...

Nginx monitoring issues under Linux

nginx installation Ensure that the virtual machin...

Vue implements sample code to disable browser from remembering password function

Find information Some methods found on the Intern...