牛客网-牛客题霸-sql入门篇-SQL33题解
描述
题目:现在运营想要找到每个学校gpa最低的同学来做调研,请你取出每个学校的最低gpa。
示例:user_profile
根据示例,你的查询结果应参考以下格式:
思路:
限定条件:gpa最低,看似min(gpa),但是要留意,是每个学校里的最低,不是全局最低。min(gpa)的时候对应同学的ID丢了,直接干是拿不到最低gpa对应的同学ID的;每个学校最低:
第一种方式是用group by把学校分组,然后计算得到每个学校最低gpa,再去找这个学校里和这个gpa相等的同学ID。注意这样如果最低gpa对应多个同学,都会输出。这里题目不做要求
select device_id,university, gpa
from user_profile
where gpa in(
select min(gpa) gpa
from user_profile
group by university
)
order by university
第二种方式是利用窗口函数,先按学校分组计算排序gpa,得到最低gpa的记录在用子查询语法拿到需要的列即可。此题中rou_number可以得到排序后的位序,取位序为1即可得到最小值(升序时)。
select device_id,university, gpa
from (
select *,
row_number() over(partition by university order by gpa asc) sd
from user_profile
) st
where st.sd=1