SQLServer行列转换 Pivot UnPivot 动态实现
来源:互联网 发布:seo搜索引擎实战详解 编辑:程序博客网 时间:2024/05/01 23:12
PIVOT用于将列值旋转为列名(即行转列),在SQL Server 2000可以用聚合函数配合CASE语句实现
PIVOT的一般语法是:PIVOT(聚合函数(列) FOR 列 in (…) )AS P
完整语法:
table_source
PIVOT(
聚合函数(value_column)
FOR pivot_column
IN(<column_list>)
)
UNPIVOT用于将列明转为列值(即列转行),在SQL Server 2000可以用UNION来实现
完整语法:
table_source
UNPIVOT(
value_column
FOR pivot_column
IN(<column_list>)
)
注意:PIVOT、UNPIVOT是SQL Server 2005 的语法,使用需修改数据库兼容级别
在数据库属性->选项->兼容级别改为 90
4、使用SQL Server 2005静态SQL
select*fromtb pivot(max(分数)for课程in(语文,数学,物理))a
5、使用SQL Server 2005动态SQL
--使用stuff()
declare@sqlvarchar(8000)
set@sql='' --初始化变量@sql
select@sql=@sql+','+课程fromtbgroupby课程--变量多值赋值
set@sql=stuff(@sql,1,1,'')--去掉首个','
set@sql='select * from tb pivot (max(分数) for课程in ('+@sql+'))a'
exec(@sql)
--或使用isnull()
declare@sqlvarchar(8000)
–-获得课程集合
select@sql=isnull(@sql+',','')+课程fromtbgroupby课程
set@sql='select * from tb pivot (max(分数) for课程in ('+@sql+'))a'
exec(@sql)
- SQLServer行列转换 Pivot UnPivot 动态实现
- SQLServer行列转换 Pivot UnPivot
- SQLServer行列转换 Pivot UnPivot
- SQLServer行列转换 Pivot UnPivot
- SQLServer行列转换 Pivot UnPivot
- SQLServer行列转换 Pivot UnPivot
- PIVOT/UNPIVOT行列转换
- Pivot UnPivot 行列转换
- Pivot UnPivot 行列转换
- SQL通过PIVOT/UNPIVOT实现行列转换
- SQl2005行列转换 pivot/unpivot
- SQL行列转换PIVOT、UNPIVOT
- [MSSQL]行列转换 Pivot UnPivot
- Oracle 通过pivot和unpivot实现行列转换
- MSSQL2005行列转换(使用PIVOT and UNPIVOT)
- PIVOT/UNPIVOT的用法(行列转换)
- SQL Server 行列转换 Pivot UnPivot
- sql server 行列转换PIVOT 和 UNPIVOT
- sdutoj 2144最小生成树
- 【BNUOJ】 特别的取石子游戏 (博弈)
- Android从相机、相册选择图片并裁剪
- 广义表-头尾链表
- HttpUnit集成测试
- SQLServer行列转换 Pivot UnPivot 动态实现
- 流式计算-Jstorm提交Topology过程(下)
- SDUT 2128 树结构练习——排序二叉树的中序遍历
- ZendFramework2学习笔记 表单过滤、表单验证
- Correct the error, mistake, Overcome the shortcomings
- zoj 2334 左偏树+并查集
- [JAVA] javaMail邮件接收
- 正则表达式-整理
- windows eclipse 远程连接 hadoop(linux)