We were trying to make a hosted web service call and retrieve the response. Following code segment was working fine for smaller responses.
set nocount on
declare @objWinHttp int
declare @strLine varchar(8000)
declare @hr int
exec @hr =sp_OACreate 'WinHttp.WinHttpRequest.5.1', @objWinHttp out
print @hr
EXEC sp_OAMethod @objWinHttp, 'Open',NULL,'GET','http://www.webservicex.com/stockquote.asmx/GetQuote?symbol=MSFT',false
EXEC sp_OAMethod @objWinHttp, 'Send',NULL
--- Problematic call
exec @hr =sp_OAGetProperty @objWinHttp, 'ResponseText',@strLine OUtPUT
---
print @hr
print @strLine
exec sp_OADestroy @objWinHttp
set nocount on
declare @objWinHttp int
declare @strLine varchar(8000)
declare @hr int
exec @hr =sp_OACreate 'WinHttp.WinHttpRequest.5.1', @objWinHttp out
print @hr
EXEC sp_OAMethod @objWinHttp, 'Open',NULL,'GET','http://www.webservicex.com/stockquote.asmx/GetQuote?symbol=MSFT',false
EXEC sp_OAMethod @objWinHttp, 'Send',NULL
--- Problematic call
exec @hr =sp_OAGetProperty @objWinHttp, 'ResponseText',@strLine OUtPUT
---
print @hr
print @strLine
exec sp_OADestroy @objWinHttp
but when response text is larger than 4000 bytes it failed with following error
-2147211494
OLE Automation Error Information
HRESULT: 0x8004271a
Source: ODSOLE Extended Procedure
Description: Error in srv_convert.
Reason:
Length of response > 4000.
Microsoft has description about the issue at http://support.microsoft.com/kb/325492
Solution:
As a workaround we created a temporary table with nvarchar column having size as max. We inserted the output of procedure to the table
--- Changed the call : removed @strLine OUtPUT
Create table #tmp(dt nvarchar(max))
insert into #tmp
exec @hr =sp_OAGetProperty @objWinHttp, 'ResponseText' --,@strLine OUtPUT
Select dt from #tmp -- single column/single row.
Drop Table #tmp -- clean up
---
It worked for us. Hope it help others.
3 comments:
Thank you for this! Been struggling with a large JSON output for a while and this did the trick perfectly.
Thank you. Greate solution !
X2, thanks a lot!!
Post a Comment