sql面试题——手写sql练习案例(一)

1.求:找出所有科目成绩都大于某一学科平均成绩的学生

uid subject_idscore
10010190
10010290
10010390
10020185
10020285
10020370
10030170
10030270
10030385

先创建表

create table score(
    uid string,
    subject_id string,
    score int)
row format delimited fields terminated by '\t'; 

 1.1 求出每个学科平均成绩

select
    uid,
    score,
    avg(score) over(partition by subject_id) avg_score
from
    score;t1

1.2 根据是否大于平均成绩记录flag,大于则记为0,否则记为1

select
    uid,
    if(score>avg_score,0,1) flag
from
    t1;t2

1.3 根据学生的id进行分组统计flag的和,和为0则是所有学科都大于平均成绩

select
    uid
from
    t2
group by
    uid
having
    sum(flag)=0;

1.4 最终sql

select
    uid
from
    (select
    uid,
    if(score>avg_score,0,1) flag
from
    (select
    uid,
    score,
    avg(score) over(partition by subject_id) avg_score
from
    score)t1)t2
group by
    uid
having
    sum(flag)=0;

2. 要求使用SQL统计出每个用户的累积访问次数

数据:

用户id(userId)月份(visitDate)计数(visitCount)
u012020-10-285
u022020-9-276
u03  2020-10-168
u042020-10-133
u012020-10-246
u012020-10-098
u022020-10-256
u012020-9-184

创建表

create table visit
(userId string,
visitDate string,
visitCount int) 
row format delimited fields terminated by "\t";

2.1 计算每人单月访问量

select
    userId,
    visitDate,
    sum(visitCount) mn_count
from
    visit
group by
    userId,visitDate;t1

2.2 按月累计访问量

select
    userId,
    visitDate,
    mn_count,
    sum(mn_count) over(partition by userId order by visitDate)
from t1;

2.3 最终sql

select
     userId,
     visitDate,
     mn_count,
     sum(mn_count) over(partition by userId order by visitDate)
from
  (select
     userId,
     visitDate,
     sum(visitCount) mn_count
from visit
group by userId,visitDate)t1;
  
    

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值