我有一些varbinary数据存储在MS Sql Server 2005中的一个表中。有没有人有SQL代码,它将查询作为输入(让我们说查询保证varbinary的一列被返回),并将字节输出到磁盘(一个文件每行?)我相信这已经被问了一千次,但谷歌提出了大多数.net解决方案。我想要一个SQL解决方案。
解决方法
BCP方法对我来说不起作用它写入磁盘的字节不能反序列化为我存储的.net对象。这意味着磁盘上的字节不等于存储的字节数。也许BCP正在写一些标题。我不确定。
我在文章的底部找到了以下代码here。它的作品很棒!虽然它是为存储的BMP图像,它适用于任何varbinary。
DECLARE @SQLIMG VARCHAR(MAX),@IMG_PATH VARBINARY(MAX),@TIMESTAMP VARCHAR(MAX),@ObjectToken INT DECLARE IMGPATH CURSOR FAST_FORWARD FOR SELECT csl_CompanyLogo from mlm_CSCompanySettingsLocalizations OPEN IMGPATH FETCH NEXT FROM IMGPATH INTO @IMG_PATH WHILE @@FETCH_STATUS = 0 BEGIN SET @TIMESTAMP = 'd:\' + replace(replace(replace(replace(convert(varchar,getdate(),121),'-',''),':','.',' ','') + '.bmp' PRINT @TIMESTAMP PRINT @SQLIMG EXEC sp_OACreate 'ADODB.Stream',@ObjectToken OUTPUT EXEC sp_OASetProperty @ObjectToken,'Type',1 EXEC sp_OAMethod @ObjectToken,'Open' EXEC sp_OAMethod @ObjectToken,'Write',NULL,@IMG_PATH EXEC sp_OAMethod @ObjectToken,'SaveToFile',@TIMESTAMP,2 EXEC sp_OAMethod @ObjectToken,'Close' EXEC sp_OADestroy @ObjectToken FETCH NEXT FROM IMGPATH INTO @IMG_PATH END CLOSE IMGPATH DEALLOCATE IMGPATH
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。