sql 合并重复记录

有一个学生成绩表A,ID,NAME,Subject,scores1,张三,语文,77s1,张三,数学,66s2,李四,语文,99s2,李四,数学,88我想查询得到:ID,... 有一个学生成绩表A,
ID,NAME,Subject,score
s1,张三,语文,77
s1,张三,数学,66
s2,李四,语文,99
s2,李四,数学,88
我想查询得到:
ID,NAME,语文,数学
s1,张三,77,66
s2,李四,99,88
应该怎样写SQL语句?麻烦各位了。
展开
 我来答
137791483
2012-07-13 · 超过27用户采纳过TA的回答
知道答主
回答量:200
采纳率:0%
帮助的人:90.8万
展开全部
select id,name, max(case
Subject when '语文' then score
else 0
end ) as 语文,
max(case
科目 when '数学' then score
else 0
end ) as 数学
from a
group by id,name

需要用case end语句来控制条件
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
793027848
2012-07-13 · TA获得超过145个赞
知道答主
回答量:94
采纳率:0%
帮助的人:32.6万
展开全部
用个分组语句,应该很好写的撒:SQL>select ID,NAME,sum(case Subject when '语文' then score else 0 end) 语文,sum(case Subject when '数学' then score else 0 end) from A group by ID,NAME;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
unitech2010
2012-07-13 · TA获得超过1062个赞
知道小有建树答主
回答量:1025
采纳率:100%
帮助的人:910万
展开全部
select id,name, max(case Subject when '语文' then score else 0 end ) 语文,
max(case 科目 when '数学' then score else 0 end ) 数学
from a
group by id,name
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友1063546
2012-07-13 · 超过12用户采纳过TA的回答
知道答主
回答量:89
采纳率:0%
帮助的人:45.6万
展开全部
这不就是行专列吗,顶楼上的……
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式