1

我正在尝试使用此 t-sql 将表中的数据直接保存到服务器文件系统:

DECLARE @ID int
DECLARE @command varchar(1000)
DECLARE @Name varchar(100)
DECLARE @FileName varchar(100)
DECLARE MyCursor CURSOR FOR 
SELECT Id, [FileName] FROM FilesTable
OPEN MyCursor 

FETCH NEXT FROM MyCursor 
INTO @ID, @Name

WHILE @@FETCH_STATUS = 0
BEGIN

SELECT @FileName = 'd:\Temp\' + convert(varchar(200), @Name)

SET @command = 'bcp "SELECT FileBytes FROM FilesTable WHERE ID = ' + convert(varchar(18),     @Id) + '" queryout "' + @FileName + '" -T -n'

EXEC master..xp_cmdshell @command, no_output

FETCH NEXT FROM MyCursor 
INTO @Id, @Name

END

CLOSE MyCursor 
DEALLOCATE MyCursor 

该表充满了可靠的数据。使用 C# 程序访问这些数据是可行的。我确实配置了高级选项,允许使用 xp_cmdshell 当我运行此查询时,我没有收到任何错误,但没有写入文件。我也没有在日志中看到任何内容,(也许我在寻找错误的位置?)

我究竟做错了什么?或者我能做些什么来检查'引擎盖下'?

4

1 回答 1

0

根据 Patrick 的评论和以最快的方式将 blob 从表导出到单个文件的答案,我能够将图像存储在我的文件服务器上。

我们最终编写了一个类似于给定的 CLR 函数。

于 2012-09-06T08:16:11.650 回答