Medium
Table: employees
+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| employee_id | int     |
| name        | varchar |
+-------------+---------+
employee_id is the unique identifier for this table.
Each row contains information about an employee. 
Table: performance_reviews
+-------------+------+
| Column Name | Type |
+-------------+------+
| review_id   | int  |
| employee_id | int  |
| review_date | date |
| rating      | int  |
+-------------+------+
review_id is the unique identifier for this table.
Each row represents a performance review for an employee.
The rating is on a scale of 1-5 where 5 is excellent and 1 is poor. 
Write a solution to find employees who have consistently improved their performance over their last three reviews.
3 review to be considered3 reviews must show strictly increasing ratings (each review better than the previous)3 reviews based on review_date for each employee3 reviewsReturn the result table ordered by improvement score in descending order, then by name in ascending order.
The result format is in the following example.
Example:
Input:
employees table:
+-------------+----------------+
| employee_id | name           |
+-------------+----------------+
| 1           | Alice Johnson  |
| 2           | Bob Smith      |
| 3           | Carol Davis    |
| 4           | David Wilson   |
| 5           | Emma Brown     |
+-------------+----------------+ 
performance_reviews table:
+-----------+-------------+-------------+--------+
| review_id | employee_id | review_date | rating |
+-----------+-------------+-------------+--------+
| 1         | 1           | 2023-01-15  | 2      |
| 2         | 1           | 2023-04-15  | 3      |
| 3         | 1           | 2023-07-15  | 4      |
| 4         | 1           | 2023-10-15  | 5      |
| 5         | 2           | 2023-02-01  | 3      |
| 6         | 2           | 2023-05-01  | 2      |
| 7         | 2           | 2023-08-01  | 4      |
| 8         | 2           | 2023-11-01  | 5      |
| 9         | 3           | 2023-03-10  | 1      |
| 10        | 3           | 2023-06-10  | 2      |
| 11        | 3           | 2023-09-10  | 3      |
| 12        | 3           | 2023-12-10  | 4      |
| 13        | 4           | 2023-01-20  | 4      |
| 14        | 4           | 2023-04-20  | 4      |
| 15        | 4           | 2023-07-20  | 4      |
| 16        | 5           | 2023-02-15  | 3      |
| 17        | 5           | 2023-05-15  | 2      |
+-----------+-------------+-------------+--------+ 
Output:
+-------------+----------------+-------------------+
| employee_id | name           | improvement_score |
+-------------+----------------+-------------------+
| 2           | Bob Smith      | 3                 |
| 1           | Alice Johnson  | 2                 |
| 3           | Carol Davis    | 2                 |
+-------------+----------------+-------------------+ 
Explanation:
The output table is ordered by improvement_score in descending order, then by name in ascending order.
# Write your MySQL query statement below
WITH Ranked AS (
    SELECT
        e.employee_id,
        e.name,
        pr.review_date,
        pr.rating,
        RANK() OVER (
            PARTITION BY e.employee_id
            ORDER BY pr.review_date DESC
        ) AS rnk,
        LAG(pr.rating) OVER (
            PARTITION BY e.employee_id
            ORDER BY pr.review_date DESC
        ) AS lag_rating
    FROM employees e
    LEFT JOIN performance_reviews pr
        ON e.employee_id = pr.employee_id
)
SELECT
    employee_id,
    name,
    MAX(rating) - MIN(rating) AS improvement_score
FROM Ranked
WHERE rnk <= 3
GROUP BY
    employee_id,
    name
HAVING
    COUNT(*) = 3
    AND SUM(CASE WHEN lag_rating > rating THEN 1 ELSE 0 END) = 2
ORDER BY
    improvement_score DESC,
    name ASC;