如何在Openrowset命令中使用变量

时间:2016-10-03 09:06:49

标签: sql sql-server openrowset

我试图在SQL Openrowset命令中使用变量文件路径。我知道它无法明确接受变量,我需要使用动态SQL。

目前有效 -

SELECT @file_stream = CAST(bulkcolumn AS VARBINARY(MAX))
FROM OPENROWSET(BULK 'C:\Temp\print4.pdf', SINGLE_BLOB) AS x

但是,如果我尝试使用我的变量文件路径

declare @file_stream VARBINARY(MAX)

declare @filePath NVARCHAR(128)
set @filePath = 'C:\Temp\print4.pdf'

set @command = N'SELECT @file_stream = CAST(bulkcolumn AS varbinary(MAX))
                from OPENROWSET(BULK ' + @filePath + ',
                SINGLE_BLOB) ROW_SET'

EXEC sp_executesql @command, @filePath, @file_stream;

我收到错误' Msg 137,Level 15,State 2,Line 15 必须声明标量变量" @ filePath"。'

我确定这是一个语法问题,但我们无法弄清楚它应该如何格式化。

1 个答案:

答案 0 :(得分:7)

更改您的脚本,如下所示。

DECLARE @file_stream VARBINARY(MAX)
DECLARE @command nvarchar(1000)
DECLARE @filePath NVARCHAR(128)
set @filePath = 'C:\Temp\print4.pdf'

set @command = N'SELECT @file_stream1 = CAST(bulkcolumn AS varbinary(MAX))
                from OPENROWSET(BULK ''' + @filePath + ''',
                SINGLE_BLOB) ROW_SET'

EXEC sp_executesql @command, N'@file_stream1 VARBINARY(MAX) OUTPUT',@file_stream1 =@file_stream OUTPUT

select @file_stream

示例输出: enter image description here