sql 2008两列的表如何可以转换为一行表?
学生表中有两列姓名与学号,如何可以转换为下面的表:列名是姓名,行名是学号。学号和姓名都是唯一的,假设不重复。是不确定的值,就不能用CAST。可能是用pivot语句实现。求...
学生表中有两列姓名与学号,如何可以转换为下面的表:
列名是姓名,行名是学号。
学号和姓名都是唯一的,假设不重复。是不确定的值,就不能用CAST。
可能是用pivot语句实现。求举例
用纯sql实现 展开
列名是姓名,行名是学号。
学号和姓名都是唯一的,假设不重复。是不确定的值,就不能用CAST。
可能是用pivot语句实现。求举例
用纯sql实现 展开
展开全部
通用的办法是用动态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,',需要进一步处理去掉最后的逗号。
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,',需要进一步处理去掉最后的逗号。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询