高频SQL 50题 | 聚合


🌈 个人主页: Hygge_Code
🔥 热门专栏:从0开始学习Java | Linux学习| 计算机网络
💫 个人格言: "既然选择了远方,便不顾风雨兼程"

文章目录

  • [P570. 至少有5名直接下属的经历](#P570. 至少有5名直接下属的经历)
  • [P1934.确认率 🍂](#P1934.确认率 🍂)
  • [P620. 有趣的电影](#P620. 有趣的电影)
    • [取模 `%`](#取模 %)
  • [P1251. 平均售价](#P1251. 平均售价)
  • [P1075. 项目员工 I](#P1075. 项目员工 I)
  • [P1533. 各赛事的用户注册率 🍂](#P1533. 各赛事的用户注册率 🍂)

P570. 至少有5名直接下属的经历

对应的SQL语句:

P1934.确认率 🍂


对应的SQL语句:

**解法一:**使用 SUM / COUNT

**解法二:**使用VAG

以下是我一开始时写的SQL语句(存在很大的问题):

sql 复制代码
SELECT 
    S.user_id,
    ROUND(COUNT(action = 'confirmed') / COUNT(C.user_id),2) AS confirmation_rate 
FROM
    Signups S
LEFT JOIN
    Confirmations C
ON
    S.user_id = C.user_id
GROUP BY
    S.user_id
  • 问题1:COUNT(action = 'confirmed') 无法正确统计确认次数

    • COUNT() 函数的逻辑是统计括号内「非 NULL 的行数」** ,而非「统计条件为 TRUE 的行数」**:****
      • action = 'confirmed'TRUE(满足确认)→ COUNT 算 1;
      • action = 'confirmed'FALSE(如 timeout/unconfirmed)→ COUNT 仍算 1(FALSE 不是 NULL);
    • 最终 COUNT(action = 'confirmed') 会等于 COUNT(C.user_id)(总操作次数),完全无法区分"确认"和"非确认"操作。
  • 问题2:MySQL 中「数值 ÷ 0」会直接返回 NULL

    • 若用户在 Confirmations 中无记录 → C.user_id 为 NULL → COUNT(C.user_id) = 0,MySQL 中「数值 ÷ 0」会直接返回 NULL

P620. 有趣的电影

对应的SQL语句:

取模 %

P1251. 平均售价


对应的SQL语句:

P1075. 项目员工 I


对应的SQL语句:

P1533. 各赛事的用户注册率 🍂

错误语句:

复制代码
SELECT 
    R.contest_id,
    ROUND( COUNT(R.user_id) / (SELECT COUNT(*) FROM Users) * 100, 2 )  AS percentage 
FROM
    Users U
LEFT JOIN
    Register R
ON 
    U.user_id = R.user_id
GROUP BY
    contest_id
ORDER BY
    percentage DESC, contest_id ASC

错误原因: 忽略了通过GROUP BY contest_id 分组后,若有User没有任何分组,则其会留下一个NULL值,而这些NULL值就会形成一个分组,后续也会参与进计算里:COUNT(NULL) = 0

解决方法:加上WHERE contest_id IS NOT NULL

对应的SQL语句:


如果我的内容对你有帮助,请 点赞 , 评论 , 收藏 。创作不易,大家的支持就是我坚持下去的动力!

相关推荐
橙序员小站6 分钟前
人人都在鼓吹的OPC,我想给你泼盆冷水
面试·创业
失去的青春---夕阳下的奔跑14 分钟前
560. 和为 K 的子数组
数据结构·算法·leetcode
海市公约37 分钟前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理
颂love1 小时前
MySQL的执行流程
android·数据库·mysql
海市公约1 小时前
一条SQL查询的完整旅程:MySQL执行流程深度解析
sql·mysql·数据库优化·执行计划·连接器·查询缓存·sql执行原理
m0_629494731 小时前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表
程序leo源1 小时前
Qt窗口详解
开发语言·数据库·c++·qt·青少年编程·c#
这个DBA有点耶2 小时前
COUNT进阶:超大表的近似计数与HyperLogLog
数据库·sql·程序人生·学习方法·dba·改行学it
武子康2 小时前
调查研究-138 全球机器人产业深度调研报告【01 篇】:市场规模、竞争格局与商业化成熟 2026
服务器·数据库·ai·chatgpt·机器人·具身智能
zhojiew2 小时前
在本地PostgreSQL使用pgvector构建生成式 AI 应用的实践
数据库·人工智能·postgresql