sqlserver 2005如何某门课程查询大于90分以上的人数占总中人数的比例?

cast((SELECTcount(1)fromGradewhereCno='0001'andgrade>=90)*100.0/(SELECTcount(1)fromGr... cast((SELECT count(1) from Grade where Cno='0001' and grade >=90)*100.0/(SELECT count(1) from Grade where Cno='0001') as decimal(18,2))[优秀率(%)]
Grade为学生成绩表。
错误信息:
展开
 我来答
Waveleter_沦
2014-03-05 · 超过10用户采纳过TA的回答
知道答主
回答量:34
采纳率:0%
帮助的人:25.6万
展开全部

select '优秀率:'+

cast(cast((select count(1) from 分数表名 where 分数列>=90) as decimal(18,2))/cast((select count(1) from 分数表名) as decimal(18,2))*100 as varchar(20))+'%'  as 优秀率


把对应表名 和 分数的列名  改成你的。

测试可用

如图

badkano
推荐于2016-12-02 · 知道合伙人体育行家
badkano
知道合伙人体育行家
采纳数:144776 获赞数:885373
团长

向TA提问 私信TA
展开全部

你算法基本正确

就是不能这么写,你看看下边的写法

select cast(cast((a.count1+0.0)*100/b.count2 as decimal(18,2)) as varchar)+'%' [优秀率(%)]
from
(select count(1) count1 from grade where cno='0001' and grade>=90) a,
(select count(1) count2 from grade where cno='0001') b
更多追问追答
追问
多谢大神,sqlserver 2005 查询每个班级某门课程的优秀率(90分及以上)、不及格率,要查寻每班某门课程的优秀率、不及格率。班级表(StudentMessage)有学号、姓名、班级。成绩表(Grade)有学号、课程号、成绩,课程表(Coursege)有课程号、课程名。
追答
select a.班级,
c.课程名,
cast(cast((sum(case when 分数>=90 then 1 else 0 end)+0.0)/count(*) as decimal(18,2)) as varchar)+'%' 优秀率,
cast(cast((sum(case when 分数<60 then 1 else 0 end)+0.0)/count(*) as decimal(18,2)) as varchar)+'%' 不及格率
from StudentMessage a,Grade b,coursege c where a.学号=b.学号 b.课程号=c.课程号 and c.课程名='xxx'
group by a.班级, c.课程名

这样试试

本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
HaiziCattle
2014-03-05 · TA获得超过125个赞
知道小有建树答主
回答量:298
采纳率:0%
帮助的人:193万
展开全部
select cno ,sum(case when grade>=90 then 1 else 0 end case ) / sum(1)
from grade
where cno='0001'
group by cno
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式