sql 2008两列的表如何可以转换为一行表?

学生表中有两列姓名与学号,如何可以转换为下面的表:列名是姓名,行名是学号。学号和姓名都是唯一的,假设不重复。是不确定的值,就不能用CAST。可能是用pivot语句实现。求... 学生表中有两列姓名与学号,如何可以转换为下面的表:
列名是姓名,行名是学号。

学号和姓名都是唯一的,假设不重复。是不确定的值,就不能用CAST。
可能是用pivot语句实现。求举例
用纯sql实现
展开
 我来答
山水阿锐
2015-06-29 · TA获得超过34.3万个赞
知道顶级答主
回答量:23.7万
采纳率:91%
帮助的人:3.3亿
展开全部
通用的办法是用动态sql解决:

declare @sql varchar(2000);

set @sql='select ''';
select @sql=@sql+列名+',' from 表名;
select @sql=left(@sql,len(@sql)-1)+''''
exec(@sql);
此外,SQL Server2005以上版本可以用XML Path解决。

SELECT 列名+',' FROM 表名 FOR XML PATH('')
这样将直接得到'a,b,c,d,d,e,',需要进一步处理去掉最后的逗号。
Rankabc
2015-06-29 · TA获得超过3561个赞
知道大有可为答主
回答量:3705
采纳率:59%
帮助的人:1075万
展开全部
你的意思是姓名是列名,但是不确定有多少列
第一列是学号是吧
追问
是的
追答

原表:


结果集:


已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式