Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/27.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ssis/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql server 在SSIS中使用临时表_Sql Server_Ssis_Temp Tables - Fatal编程技术网

Sql server 在SSIS中使用临时表

Sql server 在SSIS中使用临时表,sql-server,ssis,temp-tables,Sql Server,Ssis,Temp Tables,我使用以下SQL命令创建了ADO.NET连接管理器和DataReader源: select 'test' as testcol INTO #tmp select * from #tmp 如果单击DataReader组件中的刷新按钮,则会得到SqlException无效对象名tmp。SQL语句本身显然是有效的,并在SQLServerManagementStudio中正确执行。我还尝试在连接管理器上设置DelayValidation,但没有成功 是插入错误还是选择错误 如果只发出一

我使用以下SQL命令创建了ADO.NET连接管理器和DataReader源:

select 
   'test' as testcol
INTO
   #tmp

select * from #tmp

如果单击DataReader组件中的刷新按钮,则会得到SqlException无效对象名tmp。SQL语句本身显然是有效的,并在SQLServerManagementStudio中正确执行。我还尝试在连接管理器上设置DelayValidation,但没有成功

是插入错误还是选择错误

如果只发出一个同时包含INSERT和SELECT的命令,请尝试在SELECT之前加上分号

评论后编辑 将所有逻辑封装在存储过程中:

CREATE PROCEDURE YourProcedureName
AS
select 
   'test' as testcol
INTO
   #tmp

select * from #tmp

GO
请让您的应用程序运行以下单个SQL命令:

exec YourProcedureName
在下一个OP注释后编辑

OP没有说明他们使用的是哪个SQL Server版本,如果是2005年或更高版本,请尝试CTE:

;with CTEtemp as
(
select 
   'test' as testcol
)
select * from CTEtemp

为什么不能将其替换为选择“test”作为testcol?SSIS查询解析器可能会遇到问题,因为涉及一个临时表,并且它需要一条语句,而不是实际的SQL脚本。或者,如果您上面分享的只是一个示例,可能是这样的:

SELECT *
  FROM (SELECT 'test' AS testcol)
你能详细说明一下你在这里想要完成什么,如果是,为什么需要临时表吗?

使用sp\u executesql

你的命令会变成

exec sp_executesql @statement=N'
select 
   ''test'' as testcol
INTO
   #tmp

select * from #tmp'
必须使用nvarchar字符串,因此是N,并通过将它们加倍来转义单引号


我遇到了与您相同的问题,我就是这样解决的。

我没有使用SSIS。但是,是否有可能由于对SSIS任务可以使用的用户/上下文的权限而没有创建tmp?不确定,但如果是这种情况,我认为会出现权限错误。这只是一个简化的示例。在我的实际情况中,我需要临时表,但为了简单起见,我使用了这个示例。分号似乎没有帮助。的确,存储过程会简单得多。不幸的是,我们的服务器组阻止我在该sql server上创建存储过程,如果我将存储过程放在另一台服务器上,跨服务器连接将是次优的。幸运的是,我能够重新编写查询以不需要临时表,但我仍然对如何在SSIS中实现这一点感兴趣,因为如果你问我的话,这似乎是一个明显的不足。如果有人提出同样的问题,我可以通过将SET FMTONLY放在进程的顶部,在SET NOCOUNT ON语句之前,使带有临时表的存储进程正常运行。它绕过了“无效对象”错误,允许我将元数据直接拉入OLEDB源中。它不起作用是毫无意义的。但话说回来,这就是为什么我现在使用SqlBulkCopy和其他辅助函数在原始C中进行ETL。SSIS对于编码人员来说太臃肿了。我可能有一天会在NuGet上发布我的ETL库。