1

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

select 
   'test' as testcol
INTO
   #tmp

select * from #tmp

如果我单击 DataReader 组件中的刷新按钮,我会收到 SqlException "Invalid object name #tmp"。SQL 语句本身显然有效并在 sql server management studio 中正确执行。我还尝试在连接管理器上设置 DelayValidation,但无济于事。

4

3 回答 3

2

是 INSERT 还是 SELECT 上的错误?

如果您只发出一个包含 INSERT 和 SELECT 的命令,请尝试在 SELECT 之前放置一个分号。

OP注释后编辑
将所有逻辑封装在存储过程中:

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
于 2009-09-17T20:38:23.643 回答
0

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

SELECT *
  FROM (SELECT 'test' AS testcol)

您能否详细说明您要在这里完成的工作,如果是,为什么需要临时表?

于 2009-09-18T04:44:22.887 回答
0

利用sp_executesql

你的命令会变成

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

select * from #tmp'

您必须使用 nvarchar 字符串(因此是 N),并通过将单引号加倍来转义单引号。

我和你有同样的问题,这就是我刚刚解决的方法。

于 2016-01-27T00:20:32.007 回答