MySQL练手 --- 1934. 确认率

题目连接:1934. 确认率

思路

由题可知,两个表,一个表为Signups注册表,另一个表为Confirmations信息确认表,表的关联关系为 一对一,且user_id作为两个表的连接条件(匹配字段),使用左连接将两张表进行连接,然后添加过滤条件得到结果。

考点(或用到的知识):能够对值进行四舍五入且处理小数点位数的ROUND函数,求平均值的AVG函数,对于ENUM 类型字段进行判断的IF函数

用到的函数用法也附上

IF(value,value1,value2):如果value的值为TRUE,返回value1,否则返回value2
ROUND(x,y):返回一个对x的值进行四舍五入后最接近x的值,并保留到小数点后面Y
IFNULL(value1,value2):如果value1不为NULL,返回value1,否则返回value2

解题过程

题目要求:查找每个用户的确认率

通过查看样例表可知,对于Signups表中的user_idConfirmations表中的user_id并都与之一一对应,所以要使用 LEFT JOIN(左连接),确保每个用户都具有信息确认表的记录。

sql 复制代码
SELECT *
FROM signups s
LEFT JOIN confirmations c
ON s.user_id = c.user_id;

然后对结果集进行分组,GROUP BY s.user_id

题目要求:用户的 确认率 是 confirmed 消息的数量除以请求的确认消息的总数。没有请求任何确认消息的用户的确认率为 0 。确认率四舍五入到 小数点后两位 。

编写对应的语句

ROUND(SUM(IF(c.action = 'confirmed',1,0)) / COUNT(s.user_id),2)

SUM(IF(c.action = 'confirmed',1,0)) / COUNT(s.user_id) 等价于IFNULL(AVG(c.action = 'confirmed'), 0)

Code

sql 复制代码
# Write your MySQL query statement below
SELECT s.user_id,
ROUND(SUM(IF(c.action = 'confirmed',1,0)) / COUNT(s.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 分钟前
【后端】【Java】一文详解Spring Boot 统一日志与链路追踪实践
java·开发语言·数据库
2201_757830871 分钟前
DQL查询语句
数据库
JIngJaneIL14 分钟前
基于Java+ vueOA工程项目管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
鱼找水需要时间18 分钟前
国产银河麒麟系统安装mongodb副本集
数据库·mongodb
Logic10126 分钟前
《数据库运维》 郭文明 实验5 数据库性能监视与优化实验核心操作与思路解析
运维·数据库·sql·mysql·计算机网络技术·形考作业·国家开放大学
你真的可爱呀30 分钟前
4.前后端联调(Vue3+Vite + Express + MySQL)
mysql·node.js·vue·express
刺客xs34 分钟前
Qt ---- Qt6.5.3 连接MySQL数据库
数据库·qt·mysql
37方寸35 分钟前
MySQL系列4
mysql
TiDB 社区干货传送门44 分钟前
“医疗专业应用+分布式数据底座”:平凯数据库与金唐软件全链路赋能医疗国产化与数字化转型
数据库·分布式
德彪稳坐倒骑驴1 小时前
SQL刷题笔记-我没做出来的题目
数据库·笔记·sql