题解 | #统计复旦用户8月练题情况#
统计复旦用户8月练题情况
https://www.nowcoder.com/practice/53235096538a456b9220fce120c062b3
select
up.device_id,
university,
count(question_id) question_cnt,
sum(if (result = 'right', 1, 0)) right_question_cnt
from
user_profile up
left join question_practice_detail qpd on qpd.device_id = up.device_id and month (date) = 8
where
university = '复旦大学'
group by
device_id;
/*month (date) = 8如果放到where后面那么结果中不包括未刷题的复旦用户
left join中关于where和on条件的几个知识点:
1.多表left join是会生成一张临时表,并返回给用户
2.where条件是针对最后生成的这张临时表进行过滤,过滤掉不符合where条件的记录,是真正的不符合就过滤掉。
3.on条件是对left join的右表进行条件过滤,但依然返回左表的所有行,右表中没有的补为NULL
4.on条件中如果有对左表的限制条件,无论条件真假,依然返回左表的所有行,但是会影响右表的匹配值。也就是说on中左表的限制条件只影响右表的匹配内容,不影响返回行数。/*
查看8道真题和解析