按楼上对数据库的假设。
“学生”表包含学号(studentNum)、姓名(name)等字段,“获奖”表包含学号(studentNum)、奖项名称、奖励金额(total)等字段。
命令为:
select a.studentNum,name,count(b.studentNum) as 奖励次数,isnull(sum(total),0) as 奖励总额 from tb_Student a
left join tb_Got b on a.studentNum = b.studentNum
group by a.studentNum,name
order by 奖励次数
解释:
上述命令用到了两个知识点:
1.多表查询:select a.*,b.* from a left join b on <两表连接条件>
2.分组统计:select 分组字段1,分组字段2,统计项1,统计项2 from <表> group by 分组字段1,分组字段2 order by 统计项1
上述命令中,还用到了一些小技巧。如:
left join
count(b.studentNum)
isnull(sum(total),0)
希望能帮到你!