当前位置 鱼摆摆网 > 教程 > 电商培训 >
订单编号有什么用给别人(通过订单号查商家店铺)
公众号:猴子数据分析 作者:猴子数据分析 2021-06-05 16:01
问题1:查询出每天成功付费的付费人数、付费金额、付费单量
问题2:2013年6月14日注册用户的付费人数、付费金额
【问题1解题思路】
查询出每天成功付费的付费人数、付费金额、付费单量
1.题中提到查询“每天”的数据,涉及到“每个”这类问题要想到《猴子 从零学会SQL》里讲过的“分组汇总”来解决这里类问题
按“付费时间”分组,每天的付费人数用汇总函数(count对用户ID这一列统计有多少行),每天的付费金额用汇总函数(sum对付费金额这一列求和),每天的付费单量要用汇总函数(count对订单号这一列有多少行)
2.上面涉及到的列用户ID、付费金额、订单号都在“订单明细表”里
3.需要注意的是,要统计的是“人数”而不是“人次”,所以在统计“用户ID”时要做一次去重处理
4.题目中并没有明确说明“付费时间”的数据格式,根据日常处理数据的经验,需要用时间处理函数(date_format)先把时间格式统一为“年月日”,也就是date_format(付费时间,'%Y-%c-%d')
select date_format(付费时间,'%Y-%c-%d') as 付费时间,count(distinct 用户ID) as 付费人数,sum(付费金额) as 付费金额,count(订单号) as 付费单量from 订单明细表groupbydate_format(付费时间,'%Y-%c-%d');
5.注意统计的是“成功付费”的数据,那么需要用条件(where)指定“订单状态”为“成功”,把“失败”的订单排除在外,也就是在上一步的SQL中加入where子句
selectdate_format(付费时间,'%Y-%c-%d')as付费时间,count(distinct 用户ID) as 付费人数,sum(付费金额) as 付费金额,count(订单号) as 付费单量from 订单明细表where 订单状态 =成功groupbydate_format(付费时间,'%Y-%c-%d');
查询结果
【本题考点】
1.如果涉及到“每个”的问题,需要想到用分组汇总或者窗口函数去解决
2.考察了SQL对数据的分组应用,本题是在分组前对数据按条件筛选,使用的是where子句。如果是要对分组结果后的数据指定条件,记得是使用having,而不是where
3.考察对SQL汇总函数的应用,常用的汇总函数有以下几个:
【问题2解题思路】
查询出2013年6月14日注册用户的付费人数、付费金额
首先我们用多维度拆解分析方法对问题拆解
1.先找出“2013年6月14日注册用户”,这个数据可以从“注册表”里查找到
2.再统计“2013年6月14日注册用户”的“付费人数”和“付费金额”总数,这个数据可以从“订单明细表”里找到
3.因为涉及到两张表,所以需要用到多表联结。这道题目要我们找到的是“注册表”中有注册的用户,同时在“订单明细表”中指定日期消费过的用户,也就是两个表中“用户ID”这一列数据有交集的数据。
所有需要查找的同时出现在两张表中的共同数据,应该使用多表联结中的“内联结”(inner join)
select* from订单明细表asainnerjoin注册表asbwherea.用户ID=b.用户ID;
因为要统计的是付费人数,付费金额,我们在上一步SQL中加入汇总函数可以得到
selectcount(distinct用户ID)as付费人数,sum(付费金额) as 付费金额 from 订单明细表 as ainnerjoin注册表asbwherea.用户ID=b.用户ID;
4.找到两张表“用户ID”列共有的数据后,设置条件 where 注册表.注册时间= “2013年6月14日”。同时需要是有效订单,即订单明细表.订单状态=“成功”
5.同上一题一样,会用到时间处理函数(date_format),先把时间格式统一为“年月日”,也就是date_format(付费时间,'%Y-%c-%d')
selectcount(distinct用户ID)as付费人数,sum(付费金额) as 付费金额 from 订单明细表 as ainnerjoin注册表asbwhere a.用户ID = b.用户IDand date_format(b.注册时间,'%Y-%c-%d')=2013年6月14日anda.状态=成功;
- 全部评论(0)