2

我有一个返回 6 列的存储过程。但我只想取 2 列并将它们插入到我的表变量中。

DECLARE @CategoryTable TABLE(   
CategoryId Int NOT NULL,   
Name nvarchar(255) NOT NULL   
)  

INSERT INTO @CategoryTable EXEC [GetAllTenantCategories] @TenantId  

当我运行这个

列名或提供的值的数量与表定义不匹配

如何从存储过程中仅插入指定的列?

我不想使用SELECT INTO,因为 SQL Azure 不支持它

在下面尝试并得到Invalid object name '#Temp'

DECLARE @CategoryTable TABLE(   
CategoryId Int NOT NULL,   
Name nvarchar(255) NOT NULL   
)  
INSERT INTO #Temp EXEC [GetAllTenantCategories] 1 

INSERT INTO @CategoryTable (CategoryId, Name) 
SELECT CategoryId, Name from #Temp

DROP TABLE #Temp
4

3 回答 3

1

我们可以使用OPENQUERY

SELECT EmployeeID,CurrentSalary INTO #tempEmp 
FROM OPENQUERY(LOCALSERVER,'Exec TestDB.dbo.spEmployee')
于 2014-12-20T13:30:31.987 回答
1

您可以先创建一个temp表,然后INSERTtable variable.

CREATE TABLE #temp
(
   your columns and datatype
)


INSERT INTO #temp
EXEC [GetAllTenantCategories] @TenantId

那么你也能,

DECLARE @CategoryTable TABLE(   
 CategoryId Int NOT NULL,   
 Name nvarchar(255) NOT NULL   
 )  

INSERT INTO @CategoryTable (CategoryId, Name)
select CategoryId, Name from #temp

同时删除#temp 表,

DROP TABLE #temp
于 2013-03-24T06:27:48.423 回答
1

请参阅从https://www.simple-talk.com/sql/performance/execution-plan-basics/获取的要点

预计计划无效时

在某些情况下,估计的计划根本行不通。例如,尝试为这个简单的代码生成一个估计的计划:

CREATE TABLE TempTable
(
Id INT IDENTITY (1 , 1 )
,Dsc NVARCHAR (50 )
);

INSERT INTO TempTable ( Dsc )
SELECT [Name]
FROM [Sales] .[Store] ;

SELECT *
FROM TempTable ;

DROP TABLE TempTable ;

你会得到这个错误:

Invalid object name 'TempTable'.

用于生成估计执行计划的优化器不执行 T-SQL。

它确实通过algebrizer前面概述的过程运行语句,该过程负责验证数据库对象的名称。由于查询尚未执行,临时表还不存在。这是错误的原因。

Running this same bit of code through the Actual execution plan will work perfectly fine.

希望你明白为什么你的临时表方法不起作用:)因为你可能会尝试使用 T-SQL

于 2013-03-27T12:31:33.177 回答