Sql server 2005中实现表的行列转换
2006-10-31 12:07
375 查看
http://www.cncsk.com/Document/Database/SQL_Server/200606186744.htm
PIVOT和UNPIVOT关系运算符是SQL Server 2005提供的新增功能,因此,对升级到SQL Server 2005的数据库使用PIVOT和UNPIVOT时,数据库的兼容级别必须设置为90(可以使用sp_dbcmptlevel存储过程设置兼容级别)。 在查询的FROM子句中使用PIVOT和UNPIVOT,可以对一个输入表值表达式执行某种操作,以获得另一种形式的表。PIVOT运算符将输入表的行旋转为列,并能同时对行执行聚合运算。而UNPIVOT运算符则执行与PIVOT运算符相反的操作,它将输入表的列旋转为行。 在FROM子句中使用PIVOT和UNPIVOT关系运算符时的语法格式如下:
aggregate_function 系统或用户定义的聚合函数。注意:不允许使用COUNT(*)系统聚合函数。 value_column PIVOT运算符用于进行计算的值列。与UNPIVOT一起使用时,value_column不能是输入table_source中的现有列的名称。 FOR pivot_column PIVOT运算符的透视列。pivot_column必须是可隐式或显式转换为nvarchar()的类型。 使用UNPIVOT时,pivot_column是从table_source中提取输出的列名称,table_source中不能有该名称的现有列。 IN ( column_list ) 在PIVOT子句中,column_list列出pivot_column中将成为输出表的列名的值。 在UNPIVOT子句中,column_list列出table_source中将被提取到单个pivot_column中的所有列名。 table_alias 输出表的别名。 UNPIVOT < unpivot_clause > 指定将输入表中由column_list指定的多个列的值缩减为名为pivot_column的单个列。 常见的可能会用到PIVOT的情形是:需要生成交叉表格报表以汇总数据。交叉表是使用较为广泛的一种表格式,例如,图5-4所示的产品销售表就是一个典型的交叉表,其中的月份和产品种类都可以继续添加。但是,这种格式在进行数据表存储的时候却并不容易管理,要存储图5-4这样的表格数据,数据表通常需要设计为图5-5这样的结构。这样就带来一个问题,用户既希望数据容易管理,又希望能够生成一种能够容易阅读的表格数据。好在PIVOT为这种转换提供了便利。 图5-4 产品销售表 图5-5 数据表结构 假设Sales.Orders表中包含有ProductID(产品ID)、OrderMonth(销售月份)和SubTotal(销售额)列,并存储有如表5-2所示的内容。 表5-2 Sales.Orders表中的内容
a.PIVOT首先按值列之外的列(ProductID和OrderMonth)对输入表Sales.Orders进行分组汇总,类似执行下面的语句:
表5-3 Sales.Orders表经分组汇总后的结果
表5-4 使用FOR Orders.OrderMonth IN( [5], [6], [7] )后得到的结果集
表5-5 由表5-2所示的Sales.Orders表将行转换为列得到的最终结果集
a.首先建立一个临时结果集的结构,该结构中包含MyPvt表中除IN (五月, 六月, 七月)之外的列,以及SubTotal FOR OrderMonth中指定的值列(SubTotal)和透视列(OrderMonth)。 b.将在MyPvt中逐行检索数据,将表的列名称(在IN (五月, 六月, 七月)中指定)放入OrderMonth列中,将相应的值放入到SubTotal列中。最后得到的结果集如表5-6所示。 表5-6 使用UNPIVOT得到的结果集
| ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
相关文章推荐
- 用SQL SERVER 2005新提供的命令实现行列转换
- 在SQL Server 2005中实现表的行列转换
- 在SQL Server 2005中实现表的行列转换
- 【转载】在SQL Server 2005中实现表的行列转换
- 用SQL SERVER 2005新提供的命令实现行列转换
- 在SQL Server 2005中实现表的行列转换
- 在SQL Server 2005中实现表的行列转换()
- 在SQL Server 2005中实现表的行列转换
- 在SQL Server 2005中实现表的行列转换(转)
- SQL Server 2005之PIVOT/UNPIVOT行列转换(转)
- SQL Server 2005之PIVOT/UNPIVOT行列转换
- Sql Server函数大全(二)---SQL Server 2005 中行列转换(Pivot 和 UNPivot的使用)
- 通过创建SQL Server 2005到 Oracle10g 的链接服务器实现异构数据库数据转换方案
- Sql Server 2005 PIVOT的行列转换应用实例
- SQL Server 2005之PIVOT/UNPIVOT行列转换(转)
- SQL Server 2005之PIVOT/UNPIVOT行列转换(转)
- SQL Server 2005之PIVOT/UNPIVOT行列转换(行转列、列转行)
- 通过创建SQL Server 2005到 Oracle10g 的链接服务器实现异构数据库数据转换方案
- SQL Server 2005之PIVOT/UNPIVOT行列转换(转)
- 【转】SQL Server 2000/2005/2008 行列互相转换、合并等总结