首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用EXEC创建SQL temp表

使用EXEC创建SQL temp表
EN

Stack Overflow用户
提问于 2015-06-09 19:04:04
回答 4查看 7.4K关注 0票数 2

我需要动态地创建一个临时表,因为我不知道我将要使用的所有列。

所以假设我需要创建一个固定列的表

代码语言:javascript
运行
复制
Item int, start int, end int 

变量列(Rcpt1 int, Rcpt2 int),我设法将它放入一个nvarchar变量@columnsRcpt +2多个变量列@Start@End。因此,我尝试这样构建我的查询:

代码语言:javascript
运行
复制
@qry = 'CREATE TABLE #InvRcpt (SKU nvarchar(25), '
        + @Start + ' int' 
        + @columnsRcpt +', 
          Vendu int, 
          [Retrait d''inventaire] int, 
          Ajout int, 
          Solde int, ' 
          + @End + ' int)'
Exec(@qry)
select * from #InvRcpt

但是它不起作用,我确信我错过了一些语法方面的东西。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2015-06-09 19:20:34

如果要通过在动态查询中修改动态查询来访问动态查询外部的临时表,可以做的一件事是在动态查询之外声明它。说

代码语言:javascript
运行
复制
CREATE TABLE #InvRcpt (SKU nvarchar(25))
declare @qry nvarchar(500)
set @qry = 'alter TABLE #InvRcpt add '
    + @Start + ' int,' 
    + @columnsRcpt +', 
      Vendu int, 
      [Retrait d''inventaire] int, 
      Ajout int, 
      Solde int, ' 
      + @End + ' int'
Exec(@qry)
select * from #InvRcpt

然后,您应该获得输出,并在外部使用temp表。

票数 7
EN

Stack Overflow用户

发布于 2015-06-09 19:20:55

假设您的环境使用分号(;)作为命令终止符,请尝试以下操作

代码语言:javascript
运行
复制
@qry = 'CREATE TABLE #InvRcpt (SKU nvarchar(25), '
        + @Start + ' int' + @columnsRcpt +', Vendu int, [Retrait d''inventaire] int
        , Ajout int, Solde int, ' + @End + ' int)'
        + ';' 
        + 'select * from #InvRcpt;'

Exec(@qry)

正如Sean先前的评论所指出的,您需要在同一个批中调用SELECT语句和CREATE,以便能够获得结果。

票数 2
EN

Stack Overflow用户

发布于 2018-01-23 11:06:54

在EXEC (@qry)之外创建#InvRcpt,方法如下:

代码语言:javascript
运行
复制
IF OBJECT_ID('tempdb..##InvRcpt1') IS NULL
BEGIN
EXEC ('CREATE TABLE #InvRcpt1 (SKU nvarchar(25), ' + @Start + ' int' + @columnsRcpt + ', 
          Vendu int, 
          [Retrait d''inventaire] int, 
          Ajout int, 
          Solde int, ' + @End + ' int)')

END

SELECT *
INTO #InvRcpt
FROM ##InvRcpt1

SELECT *
FROM #InvRcpt
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30740653

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档