题解 | #月总刷题数和日均刷题数#

月总刷题数和日均刷题数

https://www.nowcoder.com/practice/f6b4770f453d4163acc419e3d19e6746

SELECT submit_month, month_q_cnt, ROUND(month_q_cnt/day_month, 3) avg_day_q_cnt
FROM (
    SELECT DATE_FORMAT(submit_time, '%Y%m') submit_month,
    COUNT(*) month_q_cnt,
    CASE WHEN MONTH(submit_time)=9 THEN 30 ELSE 31 END day_month
    FROM practice_record
    WHERE submit_time IS NOT NULL AND YEAR(submit_time) = 2021
    GROUP BY submit_month,day_month
) a
UNION 
SELECT CONCAT(DATE_FORMAT(submit_time, '%Y'), '汇总') submit_month,
    COUNT(*) month_q_cnt,
    ROUND(COUNT(*)/31,3) avg_day_q_cnt
FROM practice_record
WHERE submit_time IS NOT NULL AND YEAR(submit_time) = 2021
GROUP BY submit_month
ORDER BY submit_month

题解:

任务:找到21年每月的月活数、平均日活数

思路:观察示例发现最后有个汇总行,因此想到UNION,它和加all的区别就在于这个会自动去重。

同时月份需要格式化,使用DATE_FORMAT函数;月活数就直接使用聚合函数;日平均活跃数需要计算字段,而且每个月的日数不一样,所以采用CASE WHEN语句;

第一个使用子查询是因为分组语句的原因,MySQL的only_full_group_by模式。在这个模式下,SELECT 语句的所有列都必须是聚合的或包含在 GROUP BY 子句中,然而ROUND(month_q_cnt/day_month, 3)是计算表达式,不能用于分组。所以使用子查询的方式避免了该类错误,最后要记得给子查询一个别名。

第二个可以看到第一个字段的值是有数字和汉字,所以需要拼接,使用concat函数。 这里的ROUND(COUNT(*)/31,3) avg_day_q_cnt不报错是因为有聚合函数,并且里面也没有不能聚合的字段。同时在 GROUP BY 子句中,你只能使用实际的列名或表达式,不能使用由表达式计算出来的别名。

最后不要忘记排序

全部评论

相关推荐

今天提了离职,领导说让我离职前请几位正式工吃饭……我本来是有请客的打算的,因为感觉这几个同事人还挺好,想以后维持一下关系。但我第一次听领导主动说让实习生请客的……(只因为一个请客,倒不至于发个帖子。主要是这个公司的离谱事情太多了,跟之前的实习感受完全不同)之前几段实习,在实习结束前,mentor或领导会请客欢送,无论是私下吃个便饭也好,还是全部门的奶茶也好。这几位正式工既不是我的mentor,也不是我的领导。而且我异地实习生活很拮据,这家公司给得很少。当然了,这也算意料之外,情理之中。这家公司一直对实习生很不友好。经常让实习生加班,总是跟实习生说“辛苦一下”。你也没给我那个辛苦钱啊!晚上干到12点,周末加班干,要么是领导要看,要么是客户着急。之前的公司,我主动加班,mentor都会跟我说,实习生不用加班,到点下班就行。加班就算了,我安慰自己就当学东西了,锻炼抗压能力。但辛苦完了,节日的福利,竟然只有正式员工才有?!我之前实习,实习生的节日福利一点也不比正式工少啊……有的正式工还会把福利分给实习生一部分。挺心寒的……而且,我觉得这家公司对实习生很不负责,纯拿你当廉价劳动力。可以让刚毕业才工作三个月的人带实习生,实习生不会的,正式员工也不会,俩人就一起探索。还真就那个“和公司共同成长”😅避雷某GJ级专精特新小巨人企业,六百多人,整体氛围挺离谱的,跟我去过的其他公司完全不一样。领导都是些老东西,喜欢PUA,爹味十足。流程混乱、管理混乱、代码混乱、职责混乱,技术领导不懂技术,总说出一些可笑的畅想。虽然技术不咋地,但是把产品技术路线吹上天的本事倒是有,而且很大!什么xx系统、xx模型、xx工具,名字一个比一个高大上,其实可能就是调用Qwen、DeepSeek、Doubao……还声称这两年要上市,我祝你们成功吧😄
不知道怎么取名字_:实习的能有多少钱,为啥要请客
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务