SQL server 中使用 PIVOT关系运算符将表值表达式更改为另一个表。PIVOT 通过将表达式某一列中的唯一值转换为输出中的多个列来旋转表值表达式,并在必要时对最终输出中所需的任何其余列值执行聚合。
PIVOT 语法为SELECT <非透视的列>, [第一个透视的列],...[最后一个透视的列] FROM (<生成数据的 SELECT 查询>) PIVOT (<聚合函数>(<要聚合的列>) FOR [<包含要成为列标题的值的列>] IN ( [第一个透视的列],... [最后一个透视的列]) ) AS <透视表的别名><可选的 ORDER BY 子句>。
扩展资料:
由于SQL Server 2005有了新的PIVOT运算符,就不再需要CASE语句和GROUP BY语句了。(每个PIVOT查询都涉及某种类型的聚合,因此可以忽略GROUP BY语句。)PIVOT运算符能够利用CASE语句查询实现相同的功能,但是可以用更少的代码就实现,而且看起来更漂亮。
PIVOT运算符前面接的一定是一条查询语句。 有与PIVOT 执行相反的运算符UNPIVOT,将表值表达式的列转换为列值。相比于直接通过union来实现列转行,使用UNPIVOT可以让sql语句变得更加简洁。相对而言,理解难度会上升,可读性下降。
没在mysql中试过,不过最近在使用集算器,可以给楼主做下参考。
首先,不是所有的数据库都提供 pivot;其次,就算所有的数据库都提供 pivot,但如果是汇总了多个数据库的数据后还想再来个 pivot?那还是要用到集算器的 pivot。
下面我们来看集算器的 pivot 如何使用
代码说明:
A1:第一步连接数据库
A2:第二步提取数据做预处理 (这一步可进一步扩展为做汇总或聚合等复杂的计算,具体方法请参考相关文章)
A3:第三步即实现 pivot 的列转行功能并呈现出来
1、跟是否临时表没有关系。
2、SELECT列表中的转出字段,也要加上[]
3、加上DQ字段
SELECT DQ,[42周]
,[43周]
,[44周]
,[45周]
,[46周]
,[47周]
FROM #TEMPDBF
PIVOT( SUM(TEU) FOR
周 IN ([42周], [43周], [44周], [45周], [46周],[47周])
) b
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)