Mysql滿意度調(diào)查分組去除最高最低求平均分的實(shí)現(xiàn)思路
場景描述
我們有一個員工滿意度調(diào)查系統(tǒng),數(shù)據(jù)庫中有一張表:
survey_scores
表:存儲員工對公司的滿意度打分。
表結(jié)構(gòu)如下:
-- 調(diào)查打分表 CREATE TABLE survey_scores ( score_id INT AUTO_INCREMENT PRIMARY KEY, department VARCHAR(50), -- 部門 employee_id INT, -- 員工ID score DECIMAL(5, 2) -- 滿意度打分(0-10分) );
插入一些測試數(shù)據(jù):
-- 插入調(diào)查打分?jǐn)?shù)據(jù) INSERT INTO survey_scores (department, employee_id, score) VALUES ('HR', 1, 8.5), ('HR', 2, 9.0), ('HR', 3, 7.0), ('HR', 4, 8.0), ('HR', 5, 9.5), ('Engineering', 6, 7.5), ('Engineering', 7, 8.0), ('Engineering', 8, 6.5), ('Engineering', 9, 9.0), ('Engineering', 10, 8.5), ('Sales', 11, 6.0), ('Sales', 12, 7.0), ('Sales', 13, 6.5), ('Sales', 14, 8.0), ('Sales', 15, 7.5);
面試題
編寫一個 SQL 查詢,實(shí)現(xiàn)以下需求:
- 按部門(
department
)分組,去除每個部門的最高分和最低分。 - 計(jì)算每個部門的平均分(去除最高分和最低分后)。
- 返回以下字段:
department
(部門)avg_score
(去除最高分和最低分后的平均分)
預(yù)期結(jié)果
上述數(shù)據(jù),查詢結(jié)果類似于:
department | avg_score |
---|---|
HR | 8.17 |
Engineering | 8.00 |
Sales | 7.00 |
HR 部門:
- 原始分?jǐn)?shù):
[7.0, 8.0, 8.5, 9.0, 9.5]
- 去除最高分(9.5)和最低分(7.0)后:
[8.0, 8.5, 9.0]
- 平均分:
(8.0 + 8.5 + 9.0) / 3 = 8.17
解題思路
標(biāo)記每個部門的最高分和最低分:
- 使用窗口函數(shù)
ROW_NUMBER()
對每個部門的打分按升序和降序排名,標(biāo)記最高分和最低分。
過濾掉每個部門的最高分和最低分:
- 使用子查詢或 CTE(Common Table Expressions)過濾掉每個部門的最高分和最低分。
計(jì)算每個部門的平均分:
- 對過濾后的數(shù)據(jù)按部門分組,計(jì)算平均分。
SQL 實(shí)現(xiàn)
-- 第一步:標(biāo)記每個部門的最高分和最低分 WITH ranked_scores AS ( SELECT department, score, ROW_NUMBER() OVER (PARTITION BY department ORDER BY score ASC) AS asc_rank, ROW_NUMBER() OVER (PARTITION BY department ORDER BY score DESC) AS desc_rank FROM survey_scores ) -- 第二步:過濾掉每個部門的最高分和最低分,計(jì)算平均分 SELECT department, AVG(score) AS avg_score FROM ranked_scores WHERE asc_rank > 1 AND desc_rank > 1 -- 去除最高分和最低分 GROUP BY department;
查詢結(jié)果
上述數(shù)據(jù),查詢結(jié)果:
department | avg_score |
---|---|
HR | 8.17 |
Engineering | 8.00 |
Sales | 7.00 |
考察點(diǎn)
- 窗口函數(shù):
- 使用
ROW_NUMBER()
對每個部門的打分進(jìn)行排名。
- 使用
- 子查詢和 CTE(Common Table Expressions):
- 使用
WITH
子句將復(fù)雜查詢分解為多個步驟,提高可讀性。
- 使用
考慮mysql5.7版本
不支持窗口函數(shù)和CTS
實(shí)現(xiàn)思路
- 找到每個部門的最高分和最低分:
- 使用
GROUP BY
和MAX()
、MIN()
聚合函數(shù)找到每個部門的最高分和最低分。
- 使用
- 過濾掉每個部門的最高分和最低分:
- 使用子查詢將原始數(shù)據(jù)與最高分和最低分進(jìn)行比較,排除這些分?jǐn)?shù)。
- 計(jì)算每個部門的平均分:
- 對過濾后的數(shù)據(jù)按部門分組,計(jì)算平均分
到此這篇關(guān)于Mysql滿意度調(diào)查分組去除最高最低求平均分的文章就介紹到這了,更多相關(guān)mysql內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL系列教程小白數(shù)據(jù)庫基礎(chǔ)
這篇文章主要為大家介紹了MySQL系列中的數(shù)據(jù)庫基礎(chǔ),非常適合數(shù)據(jù)庫小白的入門基礎(chǔ)篇,詳細(xì)的講解了數(shù)據(jù)庫的基本概念以及基礎(chǔ)命令及操作示例,有需要的朋友可以借鑒參考下2021-10-10mysql中的四大運(yùn)算符種類實(shí)例匯總(20多項(xiàng))?
這篇文章主要介紹了mysql中的四大運(yùn)算符種類匯總,運(yùn)算符連接表達(dá)式中的各個操作數(shù),他的作用是用來指明對數(shù)據(jù)表中的操作數(shù)所進(jìn)行的運(yùn)算2022-07-07關(guān)于django連接mysql數(shù)據(jù)庫并進(jìn)行數(shù)據(jù)庫的創(chuàng)建的問題
這篇文章主要介紹了django連接mysql數(shù)據(jù)庫并進(jìn)行數(shù)據(jù)庫的創(chuàng)建,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06