亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何把EXEC(@SQL)得到的結果集(列是動態的)插入到一張臨時表

如何把EXEC(@SQL)得到的結果集(列是動態的)插入到一張臨時表

SMILET 2018-12-07 13:11:57
if object_id('tempdb.dbo.#TotalSalesForMonth') is not null???? drop table #TotalSalesForMonth? --刪除臨時表? select * into? #TotalSalesForMonth? from (? select ?cast(month(CreateDate) as nvarchar)?? as?? monthN, ??? sum(BaseQuantity)?? as?? total ? from?? (?select a.CreateDate,b.BaseQuantity?from? dbo.T_Sales_Order a left join dbo.T_Sales_Product as b ?on a.Id =b.ParentId ?where year(a.CreateDate)=year(getdate())? ) c? group by month(CreateDate)) pDECLARE @str VARCHAR(500) ,@Sql NVARCHAR(max)SET @str=''SELECT @str=@str+','+'['+cast(monthN as nvarchar)+']' FROM #TotalSalesForMonthSET @str=right(@str,len(@str)-1)--由于pivot 不支持 在in ()中直接添加字符串,所以需要使用 sql 拼接一下SET @Sql='select * from? #TotalSalesForMonth pivot (sum(total) for monthN in ('+@str+') ) as pvt 'if object_id('tempdb.dbo.#ForMonth') is not null???? drop table #ForMonth? --刪除臨時表? insert into #ForMonth exec(@Sql) ? (1 行受影響)消息 208,級別 16,狀態 0,第 25 行對象名? '#ForMonth' 無效。
查看完整描述

2 回答

?
慕工程0101907

TA貢獻1887條經驗 獲得超5個贊

insert into #ForMonth exec(@Sql)使用這樣的SQL語句,首先是表#ForMonth必須存在,如果不存在這個表,要用select * into #ForMonth from 表名

你可以這樣寫試一下(只后面幾句,前面的不變)

SET @Sql='select * into #ForMonth ?from? #TotalSalesForMonth pivot (sum(total) for monthN in ('+@str+') ) as pvt '
if object_id('tempdb.dbo.#ForMonth') is not null
???? drop table #ForMonth? --刪除臨時表?
exec(@Sql)

查看完整回答
反對 回復 2019-01-07
  • 2 回答
  • 0 關注
  • 640 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號