sql怎么把几行数据写到一行

如下描述:字段数据一数据二数据三我想要的结果:字段数据一\数据二\数据三就是把几行的数据显示在一行上。。。。... 如下描述:
字段
数据一
数据二
数据三
我想要的结果:
字段
数据一\数据二\数据三
就是把几行的数据显示在一行上。。。。
展开
 我来答
夕夜问情
推荐于2016-05-18 · TA获得超过537个赞
知道小有建树答主
回答量:444
采纳率:100%
帮助的人:348万
展开全部

通过case when和pivot函数均可实现行转列

--模拟数据老裤告

CREATE TABLE Test(name VARCHAR(5),Tsource VARCHAR(5),grade INT)

insert into Test VALUES ('A','语文',56)

insert into Test VALUES ('A','数学纯困',78)

insert into Test VALUES ('A','外语',60)

insert into Test VALUES ('B','语文',74)

insert into Test VALUES ('B','数学',84)

insert into Test VALUES ('C','数学',94)

insert into Test VALUES ('C','外语',56)


go

1:case when 

SELECT name,max(CASE WHEN Tsource='语文' THEN grade ELSE 0 END) as 语文,

       max(CASE WHEN Tsource='数学' THEN grade ELSE 0 END )as 数学,

       max(CASE WHEN Tsource='侍明外语' THEN grade ELSE 0 END )as 外语

  FROM Test GROUP BY name

2:pivot(PIVOT 的一般语法是:PIVOT(聚合函数(列) FOR 列 in (…) )AS P)

 select * from Test pivot

  (MAX(grade) FOR Tsource in([语文],[数学],[外语]))t

apu510064
2012-07-16 · TA获得超过964个赞
知道小有建树答主
回答量:1634
采纳率:55%
帮助的人:924万
展开全部
SQL 2005数猜燃谨据穗基库的语句参考
SELECT 字段+'/' FROM 表段判 A
WHERE
FOR XML PATH('')
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
小生阅读说
2012-07-16 · 超过14用户采纳过TA的回答
知道答主
回答量:65
采纳率:0%
帮助的人:41.9万
展开全部
select concat(数据一,'\',数据二,'\',数据三) from 表
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cczxlb
2012-07-16 · 超过10用户采纳过TA的回答
知道答主
回答量:32
采纳率:0%
帮助的人:19.3万
展开全部
select 或 聚合
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xgy92087
2012-07-16
知道答主
回答量:35
采纳率:0%
帮助的人:14.4万
展开全部
select unition
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(11)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式