将动态透视结果存储到SQLServer中的临时表中

wj8zmpe1  于 2021-07-24  发布在  Java
关注(0)|答案(1)|浏览(420)

我有下面的模式和示例数据。

create table MyTable
(
    Id int,
    Year int,
    Channel varchar(10),
    Payments int
)

insert into MyTable values 
               (1,2012,'HV',100),
               (1,2014,'HV',56),
               (2,2012,'NL',17000)
               (2,2012,'HV',495), 
               (3,2013,'HV',565)

现在我想在临时表中创建并插入动态透视数据。我可以在这里创建pivot数据作为演示。
但是我想把这些数据存储到一个临时表中。我试过的如下。

Declare @SQL varchar(max) = '    
if object_id(''tempdb..##TempTable'') is not null
begin
    drop table ##TempTable
end

create table ##TempTable([Id] int null, ' + 
            Stuff((Select Distinct ','+QuoteName(Channel + CONVERT(Varchar(4), Year)) + ' Varchar(20) null'            
            From [dbo].MyTable
            Order By 1 
            For XML Path('')),1,1,'')+ ')
INSERT INTO ##TempTable
Select *
 From (
        Select A.Id
              ,B.*
         From  [dbo].[MyTable] A
         Cross Apply ( values ( Id, Channel + CONVERT(Varchar(4), Year)
                     )) B (Item,Value)
      ) S
 Pivot (sum([Payments]) For Channel + CONVERT(Varchar(4), Year) in 
 (' + Stuff((Select Distinct ','+QuoteName(Channel + CONVERT(Varchar(4), Year))                                                               
                                               From [dbo].MyTable
                                               Order By 1 
                                               For XML Path('')),1,1,'')  + ') ) p'

select @SQL

Exec(@SQL);

SELECT * FROM ##TempTable

它给了我以下的错误。
消息102,级别15,状态1,第18行“+”附近语法不正确。
当打印动态查询时,它将给出以下结果。

if object_id('tempdb..##TempTable') is not null  
begin      
    drop table ##TempTable  
end    
create table ##TempTable([Id] int null, [HV2012] Varchar(20) null,[HV2013] Varchar(20) null,[HV2014] Varchar(20) null,[NL2012] Varchar(20) null)  
INSERT INTO ##TempTable  
    Select *   From ( Select A.Id ,B.* From  [dbo].[MyTable] A 
        Cross Apply ( values ( Id, Channel + CONVERT(Varchar(4), Year) )) B (Item,Value) ) S   
        Pivot (sum([Payments]) For Channel + CONVERT(Varchar(4), Year) in ([HV2012],[HV2013],[HV2014],[NL2012]) ) p
aij0ehis

aij0ehis1#

如果您正在使用 apply 那你为什么还需要同样的逻辑呢 PIVOT (即。 Channel + CONVERT(Varchar(4), Year) )已经在中提供 apply .
所以,我会用 Value 而是在 PIVOT :

. . . 
Pivot (sum([Payments]) For [Value] in ([HV2012],[HV2013],[HV2014],[NL2012]) ) p,

所以,你的 Dynamic SQL 可能是:

Declare @SQL varchar(max) = '    
if object_id(''tempdb..##TempTable'') is not null
begin
    drop table ##TempTable
end

create table ##TempTable([Id] int null, ' + 
            Stuff((Select Distinct ','+QuoteName(Channel + CONVERT(Varchar(4), Year)) + ' Varchar(20) null'            
            From [dbo].MyTable
            Order By 1 
            For XML Path('')),1,1,'')+ ')
INSERT INTO ##TempTable
Select *
 From (
        Select A.ID, A.Payments
              ,B.*
         From  [dbo].MyTable a 
         Cross Apply ( values ( Channel + CONVERT(Varchar(4), Year)
                     )) B ([Value])
      ) S
 Pivot (sum([Payments]) For [Value] in 
 (' + Stuff((Select Distinct ','+QuoteName(Channel + CONVERT(Varchar(4), Year))                                                               
                                               From #tm
                                               Order By 1 
                                               For XML Path('')),1,1,'')  + ') ) p'

print @sql

Exec(@SQL)

SELECT * FROM ##TempTable

我没有做任何更改,因为在执行之前需要做很多更正。

相关问题