米乐体育app官网下载

抖音直播运营面试题

covsun 2022-05-08 04:19:24 视频运营 2239 0
抖音直播运营面试题  第1张


【抖音面试题】


有一张“用户登陆记录表”,包含两个字段:用户id、日期。

抖音直播运营面试题  第2张


【问题】查询2021年每个月,连续2天都有登陆的用户名单。


【解题步骤】


1.思路


怎么能知道连续登陆用户呢?


首先对用户连续登陆进行标记,也就是日期相同的打赏同一个标记(如下图)。


抖音直播运营面试题  第3张


然后,用登陆日期的“天”和“每个月登陆顺序”的差值来做标记(如下图)。这样就可以知道,当登陆日期连续时,差值就是相同的,代表这些天用户是连续登陆。


抖音直播运营面试题  第4张


根据上图的标记,怎么查询出每个用户每个月连续登陆的天数呢?


可以用分组汇总,也就是分组(group by 月,用户id),统计(对分组后每个组计数就是连续登陆的天数 count)


2. 子查询


1)获取登陆日期的天,需要用到day()函数;


2)获取登录日期的月,需要用到month()函数;


3)获取每个月登陆顺序,这类问题属于“每个+排序”,要想到用《猴子 从零学会SQL》里讲过的知识,用到窗口函数row_number();


4)筛选出2021年的数据。


把上面内容写成SQL就是:


抖音直播运营面试题  第5张

查询结(把这个SQL记为子查询t1):


抖音直播运营面试题  第6张

用“天”和“每个月登陆顺序”的差值来做标记,也就是上面我们说过的这个图:


抖音直播运营面试题  第7张


抖音直播运营面试题  第8张

查询结果(把这个SQL记为子查询t2):


抖音直播运营面试题  第9张


3. 汇总分析


1)分组汇总:查询每个月,每个用户,每一次连续登陆的天数。


也就是分组(group by 月,用户id,标记),统计(对分组后每个组计数就是连续登陆的天数 count)


抖音直播运营面试题  第10张

查询结果(把这个SQL记为子查询t3):

抖音直播运营面试题  第11张


2)在上一步的基础上,用where子句筛选出连续2天都有登陆的用户:


抖音直播运营面试题  第12张

到这里我们已经得到了题目要求的结果,可以把前面的子查询t1、t2、t3代入上面的SQL语句,就得到了最终的SQL:

抖音直播运营面试题  第13张

查询结果:


抖音直播运营面试题  第14张


【本题考点】


1.考查对复杂问题的拆解能力,可以使用逻辑树分析方法,将一个复杂问题拆解为可以解决的子问题,然后逐步解决


2.对子查询的应用,当一个复杂问题需要多个子问题来解决时候,可以把每个子问题写成一个子查询


3.考查对常见函数的了解:month()、day()、count();


4.考查对窗口函数的应用,窗口函数能解决的几类典型问题要能牢记;



【举一反三】


查询2021年每个月,连续5天都有登陆的用户数。


与原题的区别在于:


1)“连续2天”变成了“连续5天”:对最后的where条件进行修改;


2)查询“用户名单”变成了“用户数”:用group by按月分组,然后统计用户数和count(distinct 用户id)。


抖音直播运营面试题  第15张

抖音直播运营面试题  第16张


抖音直播运营面试题  第17张


推荐:如何从零学会SQL?


抖音直播运营面试题  第18张

北京抖音AI短视频制作直播代运营服务公司

扫描二维码

手机扫一扫添加微信

扫描微信