牛客网之SQL非技术快速入门(9)-综合练习

知识点

示例:用户信息表user_profile

iddevice_idgenderageuniversitygpaactive_days_within_30
12138male21北京大学3.47
23214male复旦大学4.015
36543female20北京大学3.212
42315female23浙江大学3.65
55432male25山东大学3.820
62131male28山东大学3.315
74321female26复旦大学3.69

示例:question_practice_detail

iddevice_idquestion_idresultdate
12138111wrong2021-05-03
23214112wrong2021-05-09
33214113wrong2021-06-15
46543111right2021-08-13
52315115right2021-08-13
62315116right2021-08-14
72315117wrong2021-08-15
……

示例: question_detail

question_iddifficult_level
111hard
112medium
113easy
115easy
116medium
117easy

 34、现在运营想要了解复旦大学的每个用户在8月份练习的总题目数和回答正确的题目数情况,请取出相应明细数据,对于在8月份没有练习过的用户,答题数结果返回0.

select
  a.device_id,
  a.university,
  count(b.question_id) as question_cnt,
  sum(if(b.result = 'right', 1, 0)) as right_question_cnt
from
  user_profile a
  left join (
    select
      device_id,
      question_id,
      result,
      date
    from
      question_practice_detail
    where
      month(date) = 8
      and year(date) = 2021
  ) b on a.device_id = b.device_id
where
  a.university = "复旦大学"
group by
  a.device_id

返回以下结果:

device_iduniversityquestion_cntright_question_cnt
3214复旦大学30
4321复旦大学00

35、现在运营想要了解江大学的用户在不同难度题目下答题的正确率情况,请取出相应数据,并按照准确率升序输出。

select
  c.difficult_level,
--方法1:
sum(if(b.result = 'right', 1, 0)) / count(b.result) as correct_rate
--方法2:
sum(if(qpd.result='right', 1, 0)) / count(qpd.question_id) as correct_rate
--方法3:
count(if(qpd.result='right', 1, null)) / count(qpd.question_id) as correct_rate
from
  user_profile a
  join question_practice_detail b on a.device_id = b.device_id
  join question_detail c on b.question_id = c.question_id
where
  a.university = '浙江大学'
group by
  difficult_level
order by
  correct_rate asc

返回以下结果:

difficult_levelcorrect_rate
easy0.5000
medium1.0000


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值