从图像列导出多个图像

时间:2017-10-10 11:09:01

标签: sql .net sql-server

我有以下存储过程,如何修改它以一次导出多个图像? TicketID可以包含多个图片,IN声明可以在这里工作吗?感谢所有答案!

 CREATE PROCEDURE dbo.ExportImage (
 @ImgName NVARCHAR (100)
,@ImageFolderPath NVARCHAR(1000)
,@Filename NVARCHAR(1000)
)
AS
BEGIN

   DECLARE @ImageData VARBINARY (max);
   DECLARE @Path2OutFile NVARCHAR (2000);
   DECLARE @Obj INT

   SET NOCOUNT ON

   SELECT @ImageData = (
     SELECT convert (VARBINARY (max), ImgData, 1)
     FROM Images
     WHERE TicketID = @ImgName
     );

   SET @Path2OutFile = CONCAT (
     @ImageFolderPath
     ,'\'
     , @Filename
     );
 BEGIN TRY
 EXEC sp_OACreate 'ADODB.Stream' ,@Obj OUTPUT;
 EXEC sp_OASetProperty @Obj ,'Type',1;
 EXEC sp_OAMethod @Obj,'Open';
 EXEC sp_OAMethod @Obj,'Write', NULL, @ImageData;
 EXEC sp_OAMethod @Obj,'SaveToFile', NULL, @Path2OutFile, 2;
 EXEC sp_OAMethod @Obj,'Close';
 EXEC sp_OADestroy @Obj;
END TRY

BEGIN CATCH
EXEC sp_OADestroy @Obj;
END CATCH

SET NOCOUNT OFF
END

这是我执行的查询:
exec dbo.ExportImage '2042','C:\ExpImg','2042.jpg'

错误:

  

子查询返回的值超过1。当子查询遵循=,!=,<,< =,>,> =或子查询用作表达式时,不允许这样做。

1 个答案:

答案 0 :(得分:0)

类似的东西:

CREATE PROCEDURE dbo.ExportImage (
 @ImgName NVARCHAR (100)
,@ImageFolderPath NVARCHAR(1000)
,@Filename NVARCHAR(1000)
)
AS
BEGIN

   DECLARE @ImageData VARBINARY (max);
   DECLARE @Path2OutFile NVARCHAR (2000);
   DECLARE @Obj INT

   SET NOCOUNT ON

DECLARE @cursor CURSOR
SET @cursor = CURSOR FOR
    SELECT convert (VARBINARY (max), ImgData, 1)
     FROM Images
     WHERE TicketID = @ImgName
OPEN @cursor
FETCH NEXT
FROM @cursor INTO @ImageData
WHILE @@FETCH_STATUS = 0
BEGIN
   SET @Path2OutFile = CONCAT (
     @ImageFolderPath
     ,'\'
     , @Filename
     );
 BEGIN TRY
 EXEC sp_OACreate 'ADODB.Stream' ,@Obj OUTPUT;
 EXEC sp_OASetProperty @Obj ,'Type',1;
 EXEC sp_OAMethod @Obj,'Open';
 EXEC sp_OAMethod @Obj,'Write', NULL, @ImageData;
 EXEC sp_OAMethod @Obj,'SaveToFile', NULL, @Path2OutFile, 2;
 EXEC sp_OAMethod @Obj,'Close';
 EXEC sp_OADestroy @Obj;
END TRY

BEGIN CATCH
EXEC sp_OADestroy @Obj;
END CATCH

FETCH NEXT
FROM @cursor INTO @ImageData
END
CLOSE @cursor
DEALLOCATE @cursor

END