邹建写的语句,我初学水平太——执行不了,谁来帮我看看,只有60分了!!!

yexd1 2005-03-18 03:45:58
我得问题是关于成绩统计的,问题描述:我的成绩表是这样的[学号 姓名 年级 班级 科目 考试类型 分数],如果要统计某一科的成绩是没有问题的,但统计某班各科的成绩时遇到了一个问题:假设我要统计一年级三班各科的及格率的情况,但是我根本不知道一年级三班有几科(在成绩表里面),对于这种统计字段的数目不清楚的情况下怎么办呢?比如 select @x1,@x2,@x3,@xi from .....此时[i]的值不确定,我怎么确定我的传递参数呢?
邹建的回答:(我执行不了,帮我看看)
如果从成绩表取科目,可以用动态语句

declare @s nvarchar(4000)
set @s=''
select @s=@s+','+quotename(科目)+'=max(case 科目 when '+quotename(科目,'''')+' then 成绩 end)'
from 成绩表
where 班级='xx'
group by 科目
exec('select 学号'+@s+'
from 成绩表
where 班级=''xx''
group by 学号')

...全文
207 12 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
yexd1 2005-03-19
  • 打赏
  • 举报
回复
我想再问问,对这种纵向表格我现在知道了计算平均分、及格率、分数段的基本方法,但是我不好计算每一个人的总分,比如优生率,有什么办法吗?先谢谢啦!
yexd1 2005-03-18
  • 打赏
  • 举报
回复
谢谢邹建,我好好学习学习这么经典的语句!
zjcxc 2005-03-18
  • 打赏
  • 举报
回复
处理及格率上面已经演示了,优生率也都是类似的处理方法,自己动动脑吧
yexd1 2005-03-18
  • 打赏
  • 举报
回复
谢谢各位,这样好不容易才把科目和成绩找出来,那么我再什么地方处理数据呢(如:计算及格率,优生率...)说说方法吧???
zjcxc 2005-03-18
  • 打赏
  • 举报
回复
处理中涉及到的函数作用及用法看sql联机帮助
zjcxc 2005-03-18
  • 打赏
  • 举报
回复
--测试表
create table 成绩表(学号 int,姓名 nvarchar(10),年级 nvarchar(10),班级 nvarchar(10),科目 nvarchar(10),考试类型 nvarchar(10),分数 int)
insert 成绩表 select 1,'张三','一年级','一班','语文',1,100
insert 成绩表 select 1,'张三','一年级','一班','数学',1,50
insert 成绩表 select 2,'李四','一年级','一班','语文',1,100
insert 成绩表 select 2,'李四','一年级','一班','数学',1,100
insert 成绩表 select 3,'王五','一年级','一班','语文',1,50
insert 成绩表 select 3,'王五','一年级','一班','数学',1,50
insert 成绩表 select 4,'王五','二年级','一班','语文',1,100
go

declare @s nvarchar(4000)
set @s=''
select @s=@s+','+quotename(科目)
+'=isnull(sum(case when 科目='
+quotename(科目,'''')+' and 分数>=60 then 100.0 end),0)/sum(case when 科目='
+quotename(科目,'''')+' then 1 end)'
from 成绩表
where 年级='一年级' and 班级='一班'
group by 科目
set @s=stuff(@s,1,1,'')
exec('select --学号
'+@s+'
from 成绩表
where 年级=''一年级'' and 班级=''一班''
--group by 学号')
go

drop table 成绩表

/*--结果

数学 语文
---------------------------------------- --------------
33.333333 66.666666

--*/
yexd1 2005-03-18
  • 打赏
  • 举报
回复
再请问xluzhong:quotename(科目,'''')的执行效果是什么?
还有这句话select @s=@s+','+quotename(科目,'''')+'=max(case 科目 when '+quotename(科目,'''')+' then 成绩 end)'
from 成绩表
where 班级='xx'
group by 科目
是把科目依次显示出来吗?如 语文 数学 ...
88  88 ...
90  77 ...
90 88 ...
... ... ...
如果我要统计及格率怎么办?
子陌红尘 2005-03-18
  • 打赏
  • 举报
回复
declare @s nvarchar(4000)
set @s=''

select @s=@s+','+quotename(科目)+'=max(case 科目 when '+quotename(科目,'''')+' then 成绩 end)'
from 成绩表
where 班级='xx'
group by 科目

set @s = 'select 学号'+@s+' from 成绩表 where 班级=''xx'' group by 学号'

--看不明白不要紧,先把动态SQL语句打印出来看一下:
print @s

exec(@s)
zjcxc 2005-03-18
  • 打赏
  • 举报
回复
--测试表
create table 成绩表(学号 int,姓名 nvarchar(10),年级 nvarchar(10),班级 nvarchar(10),科目 nvarchar(10),考试类型 nvarchar(10),分数 int)
insert 成绩表 select 1,'张三','一年级','一班','语文',1,100
insert 成绩表 select 1,'张三','一年级','一班','数学',1,100
insert 成绩表 select 2,'李四','一年级','一班','语文',1,100
insert 成绩表 select 2,'李四','一年级','一班','数学',1,100
insert 成绩表 select 3,'王五','一年级','一班','语文',1,100
insert 成绩表 select 3,'王五','一年级','一班','数学',1,100
insert 成绩表 select 4,'王五','二年级','一班','语文',1,100
go

declare @s nvarchar(4000)
set @s=''
select @s=@s+','+quotename(科目)+'=max(case 科目 when '+quotename(科目,'''')+' then 分数 end)'
from 成绩表
where 年级='一年级' and 班级='一班'
group by 科目
exec('select 学号'+@s+'
from 成绩表
where 年级=''一年级'' and 班级=''一班''
group by 学号')
go

drop table 成绩表

/*--结果
学号 数学 语文
----------- ----------- -----------
1 100 100
2 100 100
3 100 100
--*/
631799 2005-03-18
  • 打赏
  • 举报
回复
不明白
niuniu777 2005-03-18
  • 打赏
  • 举报
回复
你用print 命令,把整个语句显示出来,在好好分析吧.
xluzhong 2005-03-18
  • 打赏
  • 举报
回复
declare @s nvarchar(4000)
set @s=''
select @s=@s+','+quotename(科目,'''')+'=max(case 科目 when '+quotename(科目,'''')+' then 成绩 end)'
from 成绩表
where 班级='xx'
group by 科目
exec('select 学号'+@s+'
from 成绩表
where 班级=''xx''
group by 学号')
在Windows 10或Windows 11操作系统中,用户经常会遇到共享打印机时出现的一系列错误代码,这些错误代码可能会阻碍打印机共享功能的正常使用。常见的错误代码包括0x00000057、0x00000709和0x0000011b,这些代码通常指出了不同的问题,比如权限不足、服务未运行或配置错误等。除此之外,还有一些故障提示如“连接失败”或“内存不足”,这些都可能影响到打印机共享的稳定性。 要解决这些故障,首先要确保打印机已经正确地连接到网络,并且在需要共享的电脑上进行了设置。确保打印机驱动程序是最新的,并且在共享设置中没有错误配置。对于权限问题,需要检查网络上的用户账户是否具有足够的权限来访问共享打印机。同时,也要确保打印机服务正在运行,特别是“Print Spooler”服务,因为这是打印机共享服务的核心组件。 在某些情况下,问题可能与操作系统的更新有关,如升级到最新版的Windows 10或Windows 11后可能出现的兼容性问题。这时,可能需要查看微软的官方支持文档来获取特定的解决方案或更新。 对于错误代码0x00000057,这通常是由于没有足够的权限来访问网络打印机或其共享资源,解决方法是确保网络打印机的权限设置正确,包括在组策略中设置相应的访问权限。而0x00000709错误可能是由于打印机驱动问题或打印机端口配置错误,可以尝试重新安装或更新打印机驱动来解决。至于0x0000011b错误,这往往是因为打印机队列服务的问题,检查并重启“Print Spooler”服务通常是解决这类问题的常见手段。 至于“连接失败”或“内存不足”这类故障,通常与客户端和打印机之间的网络连接以及打印机本地资源的使用情况有关。检查网络连接,确保打印机所在的网络段没有故障或中断。同时,如果打印机的打印队列长时间得不到处理,可能会导致内存不足的情况,这时可能需要清理打印队列或增加打印机的内存配置。 为了助用户更快速地解决这些问题,市面上出现了各种打印机共享错误修复工具。这些工具往往通过预设的修复程序来自动检测和修正打印机共享中常见的问题。它们可以快速检查打印机驱动、网络连接以及共享设置,并且能够提供一键修复功能,大幅减少了用户自行排查和解决问题的难度。 然而,在使用这些修复工具之前,用户应确保这些工具的来源是安全可靠的,避免因使用不当的修复工具而引发其他系统安全或隐私问题。用户可以到官方平台或者信誉良好的软件提供商处下载这些工具。通过细心检查打印机的共享设置,及时更新驱动程序和服务,以及合理使用修复工具,大多数共享打印机的问题都可以得到有效的解决。

27,582

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧