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