MySQL练手 --- 1633. 各赛事的用户注册率

题目链接:1633. 各赛事的用户注册率

思路:

两张表,一张为Users用户表,该表存储着所有用户的 user_iduser_name

另一张表为Register注册表,该表存储着赛事id(contest_id),和已报名的用户id(user_id

题目要求:统计出各赛事的用户注册百分率,保留两位小数。

返回的结果表按 percentage 的 降序 排序,若相同则按 contest_id 的 升序 排序。

对赛事进行分组,然后分别对各赛事统计表名人数,最后除以总人数。

解题过程:

先求总人数,并给表别名为total_table,统计后的总人数的字段为total

sql 复制代码
SELECT COUNT(user_id) total
FROM users

得到总人数后,对各赛事的人数进行统计

sql 复制代码
SELECT contest_id, COUNT(user_id)
FROM register
GROUP BY contest_id

然后将各赛事的人数除以总人数且用户注册百分率保留两位小数(ROUND((COUNT(user_id) / total) * 100,2)

sql 复制代码
SELECT contest_id, ROUND((COUNT(user_id) / total) * 100,2) percentage 
FROM register r, (SELECT COUNT(user_id) total
FROM users) total_table
GROUP BY contest_id 

最后再加上排序即可(ORDER BY percentage DESC, contest_id

Code

sql 复制代码
SELECT contest_id, ROUND((COUNT(user_id) / total) * 100,2) percentage 
FROM register r, (SELECT COUNT(user_id) total
FROM users) total_table
GROUP BY contest_id 
ORDER BY percentage DESC, contest_id 
相关推荐
·云扬·9 分钟前
InnoDB Cluster高可用测试实战:主从切换与故障恢复验证
数据库·mysql
oMcLin21 分钟前
Ubuntu 24.04系统 防火墙配置问题导致 MySQL 无法远程连接:firewalld 与 iptables 的冲突排查
linux·mysql·ubuntu
qq_4557608538 分钟前
redis - 持久化
数据库·redis·缓存
&友情岁月&42 分钟前
sql脚本的union的要注意点
数据库·sql
nvd111 小时前
基于 LangChain + Gemini + CloudSQL (pgvector) 的 RAG 实现指南
数据库·langchain
oMcLin1 小时前
Ubuntu 22.04 系统升级后 PostgreSQL 无法启动:如何解决数据库迁移中的兼容性问题
数据库·ubuntu·postgresql
福尔摩斯张1 小时前
STM32数码管和LCD显示技术深度解析(超详细)
数据库·stm32·单片机·嵌入式硬件·mongodb
公众号:ITIL之家1 小时前
服务价值体系重构:在变化中寻找不变的运维本质
java·运维·开发语言·数据库·重构
技术不打烊1 小时前
InnoDB 核心原理拆解:缓冲池、Redo Log、MVCC 的底层逻辑
后端·mysql
橙汁味的风1 小时前
《数据库系统概论》陈红、卢卫 - 11 - 数据库恢复技术
数据库·数据库系统概论