Sql Server 2008的动态交叉表
  TEZNKK3IfmPf 2024年08月09日 64 0

今天又帮别人写了一段动态交叉表,几年没搞了,生疏了点,马上再记录一下

DECLARE @S VARCHAR(MAX)
SET @S = ''
SELECT  @S = @S + ',[' + TypeName + ']'
FROM    View_Analogy_DynamicQuery
GROUP BY TypeName
SET @S = STUFF(@S, 1, 1, '')

DECLARE @max VARCHAR(MAX)
SET @max = ''
SELECT  @max = @max + ',MAX([' + TypeName + ']) as [' + TypeName + ']'
FROM    View_Analogy_DynamicQuery
GROUP BY TypeName
SET @max = STUFF(@max, 1, 1, '')

EXEC('
select ResType,ReservoirVersionID,'+@max+' FROM (
select ResType,ReservoirVersionID,'+@S+' FROM View_Analogy_DynamicQuery 
PIVOT
( max(value)
for TypeName in ('+@S+')
) as PT ) x GROUP BY ResType,ReservoirVersionID
')
PIVOT 这个关键字前面貌似只能写from 某个表,如果from a join b on a.id = b.id 这样总是报错,无法深究到原因了,用一个视图把它封起来了
【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2024年08月09日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   2024年05月17日   74   0   0 mysqlsql
  TEZNKK3IfmPf   2024年07月27日   60   0   0 javasql
  TEZNKK3IfmPf   4天前   28   0   0 sql
  TEZNKK3IfmPf   2024年06月14日   89   0   0 java大数据sql
  TEZNKK3IfmPf   2024年07月27日   28   0   0 数据库sql
  TEZNKK3IfmPf   2024年07月27日   26   0   0 编程开发sql
TEZNKK3IfmPf