sql – 将varbinary数据保存到磁盘的脚本

发布时间:2019-03-09 整理:脚本之家 作者:未知
脚本之家收集整理的这篇文章主要介绍了sql – 将varbinary数据保存到磁盘的脚本脚本之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随脚本之家小编过来看看吧!
我有一些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

总结

以上是脚本之家为你收集整理的sql – 将varbinary数据保存到磁盘的脚本全部内容,希望文章能够帮你解决sql – 将varbinary数据保存到磁盘的脚本所遇到的程序开发问题。

如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。