sql – 将varbinary数据保存到磁盘的脚本
发布时间:2020-05-24 09:06:40 所属栏目:MsSql 来源:互联网
导读:我有一些varbinary数据存储在MS Sql Server 2005中的一个表中。有没有人有SQL代码,它将查询作为输入(让我们说查询保证varbinary的一列被返回),并将字节输出到磁盘(一个文件每行?)我相信这已经被问了一千次,但谷歌提出了大多数.net解决方案。我想要一个SQL
|
我有一些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 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
