职业IT人-IT人生活圈

 找回密码
 成为会员
搜索
查看: 730|回复: 2

sql 查询语句

[复制链接]
十六 发表于 2009-8-15 11:52 | 显示全部楼层 |阅读模式
学生表:T_Student

studentid 学生编号 主键
studentname 学生姓名
classid 班级编号

班级表:T_Class

classid 班级编号 主键
classname 班级名称

学科表:T_Science

scienceid 学科编号 主键
sciencename 学科名称

成绩表:T_Results

studentid 学生编号 主键
scienceid 学科编号 主键
testdate 考试时间 主键
score 分数

显示学生姓名和不及格的次数

显示学生姓名,学科名称,时间,成绩状况(分数为85以上包含85为A 70-84为B 60-69为C 其他为D)
东莞维维 发表于 2009-8-15 11:53 | 显示全部楼层

sql 查询语句

1.显示学生姓名和不及格的次数
select studentname,count(score<60) from T_Results a INNER JOIN T_Student b on a.studentid =b.studentidorder by studentname ;
2显示学生姓名,学科名称,时间,成绩状况(分数为85以上包含85为A 70-84为B 60-69为C 其他为D)






有点麻烦


3表连接

在分组

麻烦啊
小明 发表于 2009-8-15 11:53 | 显示全部楼层

sql 查询语句

/*显示学生姓名和不及格的次数*/
select a.studentname,b.不及格次数 from T_Student a
join
(select studentid,count(score) 不及格次数
from T_Results
where score<60
group by studentid) b on a.studentid=b.studentid

/*显示学生姓名,学科名称,时间,成绩状况*/
select a.studentname 学生姓名
,b.sciencename 学科名称
,c.testdate 时间
,成绩状况=(case when score>=85 then &#39;A&#39;
when score>=70 and score<85 then &#39;B&#39;
when score>=60 and score<70 then &#39;C&#39;
else &#39;D&#39; end)
from T_student a,T_science b,T_Results c
where a.studentid=c.studentid
and b.scienceid=c.scienceid
您需要登录后才可以回帖 登录 | 成为会员

本版积分规则

QQ|手机版|小黑屋|网站帮助|职业IT人-IT人生活圈 ( 粤ICP备12053935号-1 )|网站地图
本站文章版权归原发布者及原出处所有。内容为作者个人观点,并不代表本站赞同其观点和对其真实性负责,本站只提供参考并不构成任何投资及应用建议。本站是信息平台,网站上部分文章为转载,并不用于任何商业目的,我们已经尽可能的对作者和来源进行了通告,但是能力有限或疏忽造成漏登,请及时联系我们,我们将根据著作权人的要求立即更正或者删除有关内容。

GMT+8, 2024-4-28 04:43 , Processed in 0.125041 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表