MySQL–第4关:查询用户日活数及支付金额

MySQL--第4关:查询用户日活数及支付金额 -- WhiteNight's Site

标签:MySQL

非常好的题,爱来自中国。

题目
没啥用

任务描述

现有3张业务表,详见如下:

需要输出结果如下,没有支付的日期不需要显示,请写出对应的MYSQL

示例1 输入: CREATE TABLE new_user( user_id int(11) NOT NULL, is_new int(11) NOT NULL, PRIMARY KEY (user_id) ); CREATE TABLE user_pay( user_id int(11) NOT NULL, pay_money int(11) NOT NULL, dt char(20) NOT NULL ); CREATE TABLE login_record( user_id int(11) NOT NULL, login_time char(20) NOT NULL, dt char(20) NOT NULL ); insert into new_user values(1,0); insert into new_user values(2,1); insert into new_user values(3,1); insert into new_user values(4,0); insert into new_user values(5,0); insert into new_user values(6,1); insert into new_user values(7,0); insert into new_user values(8,1); insert into user_pay values(1,30,'2021-11-10′); insert into user_pay values(1,100,'2021-11-10′); insert into user_pay values(2,500,'2021-11-11′); insert into user_pay values(2,200,'2021-11-12′); insert into user_pay values(3,1000,'2021-11-10′); insert into user_pay values(4,800,'2021-11-12′); insert into user_pay values(6,1200,'2021-11-10′); insert into user_pay values(6,700,'2021-11-14′); insert into login_record values(1,'8:00′,'2021-11-10′); insert into login_record values(1,'12:00′,'2021-11-10′); insert into login_record values(1,'13:00′,'2021-11-10′); insert into login_record values(2,'16:00′,'2021-11-10′); insert into login_record values(2,'12:35′,'2021-11-11′); insert into login_record values(2,'18:34′,'2021-11-12′); insert into login_record values(3,'20:00′,'2021-11-10′); insert into login_record values(4,'21:00′,'2021-11-12′); insert into login_record values(5,'21:00′,'2021-11-13′); insert into login_record values(6,'22:30′,'2021-11-10′); insert into login_record values(6,'13:30′,'2021-11-14′);

输出: dt dau dau_new total_pay total_pay_new 2021-11-10 4 3 2330 2200 2021-11-11 1 1 500 500 2021-11-12 2 1 1000 200 2021-11-14 1 1 700 700

解题思路
看图

记录下几个用到的知识点:

  • 通过派生表来去重。如果我需要从一个已经去重过的结果集中挑选结果,那就是要用到派生表。需要注意的是既然叫派生表,那么你应该把它当成独立的一张表看。即返回的字段数要大于等于你select的字段数。
  • 聚合函数中的IF。可以在聚合函数里面加IF来计算满足某个条件的数据。需要注意的是如果不满足条件需要返回NULL。因为聚合函数计算的是结果集中"存在",即非NULL的数据。所以返回0对于聚合函数而言是"存在",返回NULL才是"不存在"。
  • 左联结+聚合函数。左联结中无法匹配的地方会被填上NULL表示"不存在可匹配的数据"。为什么方便聚合函数的计算原因如上条所述。

其实从输出中反推就行了,一步一步去LEFT JOIN新表+条件判断去筛选结果,最后从左到右逐步得出输出结果。

复制代码
USE myusers;
########## Begin ##########
SELECT A.dt,COUNT(DISTINCT A.user_id) AS dau,SUM(B.is_new) AS dau_new
,SUM(C.pay_money) AS total_pay
,SUM(IF(B.is_new=1,C.pay_money,NULL)) AS total_pay_new
FROM(SELECT DISTINCT user_id,dt
FROM login_record)A
LEFT JOIN new_user AS B
ON A.user_id=B.user_id
LEFT JOIN user_pay AS C
ON C.user_id=A.user_id AND C.dt=A.dt
GROUP BY A.dt
HAVING SUM(C.pay_money) IS NOT NULL

########## End ##########

This Website © 2023 by White Night is licensed under CC BY-NC-SA 4.0

相关推荐
wangmengxxw19 分钟前
Spring-常用注解
java·数据库·spring·注解
m0_7472660931 分钟前
contentprovider实验+SQLite数据库的实现
数据库·sqlite
_码农1213838 分钟前
spring boot + mybatis + mysql 只有一个实体类的demo
spring boot·mysql·mybatis
我是好小孩1 小时前
Android-侧边导航栏的使用
android·gitee
吗喽对你问好1 小时前
安卓基础布局核心知识点整理
android·gitee
TDengine (老段)1 小时前
TDengine 中 TDgp 中添加机器学习模型
大数据·数据库·算法·机器学习·数据分析·时序数据库·tdengine
安卓开发者1 小时前
Android Material Components 全面解析:打造现代化 Material Design 应用
android
教程分享大师1 小时前
带root权限_中国移动创维DT541_S905L3融合机器改机顶盒刷机教程 当贝纯净版安卓9.0系统线刷包 刷机包
android
wuk9981 小时前
Android:UI:Drawable:View/ImageView与Drawable
android·ui
网安Ruler1 小时前
Web开发-PHP应用&Cookie脆弱&Session固定&Token唯一&身份验证&数据库通讯
前端·数据库·网络安全·php·渗透·红队