| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 437 人关注过本帖
标题:请教关于查询问题。。。。
只看楼主 加入收藏
supercowboy
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2010-10-19
结帖率:0
收藏
 问题点数:0 回复次数:2 
请教关于查询问题。。。。
基于“学生”、“获奖”表,查询所有学生奖励次数及奖励总额,要求输出学号、姓名、奖励次数及奖励总额,并按获奖次数升序排序。。。学号为主键

[ 本帖最后由 supercowboy 于 2012-5-13 12:25 编辑 ]
搜索更多相关主题的帖子: 查询 姓名 
2012-05-13 11:45
筱晓绾
Rank: 10Rank: 10Rank: 10
来 自:湖南
等 级:贵宾
威 望:12
帖 子:512
专家分:1736
注 册:2010-9-1
收藏
得分:0 
暂定学号为studentNum,姓名为name,奖励次数为countGot,奖励总额为total,学生表为tb_Student,获奖表为tb_Got.
select a.studentNum,name,countGot,total from tb_Student a
left join tb_Got b on a.studentNum = b.studentNum
order by a.countGot asc
2012-05-15 15:33
netlin
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:24
帖 子:544
专家分:4308
注 册:2012-4-9
收藏
得分:0 
按楼上对数据库的假设。
“学生”表包含学号(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)

希望能帮到你!

做自己喜欢的事!
2012-05-21 23:29
快速回复:请教关于查询问题。。。。
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.028345 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved