SQL行列转换2
2013-03-04 10:57
417 查看
--生产测试数据 if not object_id('Class') is null drop table Class Go Create table Class([Student] nvarchar(2),[数学] int,[物理] int,[英语] int,[语文] int) Insert Class select N'李四',77,85,65,65 union all select N'张三',87,90,82,78 go declare @s nvarchar(4000),@s2 nvarchar(4000),@s3 nvarchar(4000),@s4 nvarchar(4000) select @s=isnull(@s+',','declare ')+'@'+rtrim(Colid)+' nvarchar(4000)', @s2=isnull(@s2+',','select ')+'@'+rtrim(Colid)+'='''+case when @s2 is not null then 'union all select' else ' select ' end+' [科目]='''+quotename(Name,'''')+'''''', @s3=isnull(@s3,'')+'select @'+rtrim(Colid)+'=@'+rtrim(Colid)+'+'',''+quotename([Student])+''=''+quotename('+quotename(Name)+','''''''') from Class ', @s4=isnull(@s4+'+','')+'@'+rtrim(Colid) from syscolumns where id=object_id('Class') and Name not in('Student') --print @s+' '+@s2+' '+@s3+' exec('+@s4+')' 显示执行语句 exec(@s+' '+@s2+' '+@s3+' exec('+@s4+')') /* 科目 李四 张三 ---- ---- ---- 数学 77 87 物理 85 90 英语 65 82 语文 65 78 */
相关文章推荐
- SQL面试题练习-实现pivot行列转换
- 行列转换-->动态SQL语句例子
- SQL行列转换实战
- SQL普通行列转换
- SQL语句行列转换(附带数据库、表、视图操作)
- MSSql行列转换的Sql语法 详解与实例
- 瑞丽的SQL-SQL Server的表旋转(行列转换)
- SQL语句行列转换两种方法 case ...when 和pivot函数应用
- sql2005 行列转换的例子
- 使用 PIVOT 和 UNPIVOT(MS SQL Server行列转换)
- sql为了实现转换的行列
- SQL查询中行列转换 Pivot UnPivot,行显转列显
- SQL行列转换实战
- SQL行列转换实例
- sql所有行列转换
- SQL语句行列转换
- [转]行列转换等经典SQL语句
- SQL行列转换PIVOT、UNPIVOT
- 行列转换等经典SQL语句
- SQL 行列转换查询