sql 分组问题!求高手解答

啊彪123 2010-06-06 05:17:07
假设有张学生成绩表(tb)如下:
姓名 课程 分数

张三 语文 74

张三 数学 83

张三 物理 93

李四 语文 74

李四 数学 84

李四 物理 94

想变成(得到如下结果):

姓名 语文 数学 物理

李四 74 84 94

张三 74 83 93

...全文
45 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
jaydom 2010-06-06
  • 打赏
  • 举报
回复

declare @s nvarchar(4000)
set @s=''
Select @s=@s+','+ quotename(课程,'''')+'=sum(case 课程 when '+quotename(课程,'''')+' then 分数 else 0 end)'
from tb group by 课程
--print @s

exec('select [姓名]'+@s+' from tb group by [姓名]')

姓名 数学 物理 语文
李四 84 94 74
张三 83 93 74
jaydom 2010-06-06
  • 打赏
  • 举报
回复


---动态
declare @s nvarchar(4000)
set @s=''
Select @s=@s+','+ quotename(课程+'分数')+'=sum(case 课程 when '+quotename(课程,'''')+' then 分数 else 0 end)'
from tb group by 课程
--print @s

exec('select [姓名]'+@s+' from tb group by [姓名]')


姓名 数学分数 物理分数 语文分数
李四 84 94 74
张三 83 93 74
sgtzzc 2010-06-06
  • 打赏
  • 举报
回复
select 
姓名,
语文=max(case when 课程='语文' then 分数 else 0 end),
数学=max(case when 课程='数学' then 分数 else 0 end),
物理=max(case when 课程='物理' then 分数 else 0 end)
from tb
group by 姓名
jaydom 2010-06-06
  • 打赏
  • 举报
回复

select 姓名 , sum(case 课程 when '语文' then 分数 else 0 end) 语文,
sum(case 课程 when '数学' then 分数 else 0 end) 数学,
sum(case 课程 when '物理' then 分数 else 0 end) 物理
from tb
group by 姓名

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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