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

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

标签:MySQL

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

题目

没啥用

任务描述

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

,

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

,

示例1 输入: CREATE TABLE new_useruser_id int(11) NOT NULL, is_new int(11) NOT NULL, PRIMARY KEY (user_id) ); CREATE TABLE user_payuser_id int(11) NOT NULL, pay_money int(11) NOT NULL, dt char(20) NOT NULL ); CREATE TABLE login_recorduser_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 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值