June 25, 2008 at 5:47 am
Hi All,
I have an SQL 2005 64-bit server. I am trying to call a procedure on an Oracle server and pass it params and then get some back.
The developer says that its working on the Oracle side but SQL is not allowing result params through. SQL error is:
Start USP_TestOracleCall
OLE DB provider "OraOLEDB.Oracle" for linked server "ICLPRDA" returned message "ORA-06502: PL/SQL: numeric or value error: character string buffer too small
ORA-06512: at line 1". Ids DEAL01 1-111
OLE DB provider "OraOLEDB.Oracle" for linked server "ICLPRDA" returned message "ORA-06502: PL/SQL: numeric or value error: character string buffer too small
ORA-06512: at line 1". Ids DEAL02 2-111
Msg 7215, Level 17, State 1, Procedure USP_TestOracleCall, Line 50
Could not execute statement on remote server 'ICLPRDA'.
Msg 7215, Level 17, State 1, Procedure USP_TestOracleCall, Line 50
Could not execute statement on remote server 'ICLPRDA'.
The code for the procedure in SQL is:
BEGIN
DECLARE@Deal_Id nvarchar(50)
DECLARE@Id nvarchar(50)
DECLARE @Out_Deal_Id int
DECLARE Deal_Ids CURSOR FOR
SELECTId , Deal_Id
FROMT_Test_Transaction
OPENDeal_Ids
FETCH NEXT FROM Deal_Ids INTO @Id, @Deal_Id
PRINT N'Start USP_TestOracleCall'
WHILE @@FETCH_STATUS = 0
BEGIN
EXEC ( 'BEGIN test_transaction(pi_in_recnum => ?,
pi_in_deal_id => ? , po_out_deal_id => ?
); END;',@Id, @Deal_Id, @Out_Deal_Id = '11')
AT [ICLPRDA];
PRINT N' Ids ' + @Deal_Id + @Id + ISNULL(LTRIM(RTRIM(@Out_Deal_Id)),'-111')
FETCH NEXT FROM Deal_Ids INTO @Id, @Deal_Id
END
CLOSEDeal_Ids
DEALLOCATE Deal_Ids
END
On the linked server I have set RPC and RPC_OUT to be true. To start with I couldn’t send out the params and setting RPC_OUT to true solved this (that’s why i hoped RPC would let value back through)
Appreciate any ideas people have as this is head-scratchily annoying.
Adam Zacks-------------------------------------------Be Nice, Or Leave
June 25, 2008 at 12:48 pm
try using openquery instead or EXEC. i know EXEC is much faster but it will work with openquery.
June 26, 2008 at 3:58 am
Hey Grasshopper,
Thanks for your reply. I actually started off with 'SELECT * FROM OPENQUERY(......)' but found that it didn’t really work.
It works fine to query a table or as a nested query, but in this case I don’t want to start with a query as I am just calling a sp in Oracle.
Or am I explaining wrong? The original attempt with OPENQUERY failed to execute because there was nothing to display (from the outer query) and OPENQUERY wont work on its own.
I was sure that OPENQUERY was the key, but couldn’t find a way to make it work. Any ideas?
Adam Zacks-------------------------------------------Be Nice, Or Leave
June 26, 2008 at 5:27 am
how about dynamic sql using openquery
June 26, 2008 at 7:30 am
Sorry, you've lost me. 'Dynamic SQL'?
Adam Zacks-------------------------------------------Be Nice, Or Leave
June 26, 2008 at 8:41 am
Ok, I understand now. This sort of query doesn’t seem to work because you have to do 'Select.... Openquery(....)'. That’s not working cause there is nothing to output from the 'Select' part.
That’s the reason behind the 'Exec'. All we are trying to do is pass values to Oracle sp via a cursor. Are we using this completely wrong? Please see code at start of thread, that’s what we have and it works on Oracle side, but is not passing values back.
Is it even possible. Appreciate all you help.
Adam Zacks-------------------------------------------Be Nice, Or Leave
July 3, 2008 at 2:02 pm
Hi
Check out the below link
http://searchsqlserver.techtarget.com/expert/KnowledgebaseAnswer/0,289625,sid87_gci1123229,00.html
This will slove yuor problem.
Thanks -- Vj
July 21, 2008 at 5:06 pm
Here is a link from another post that might help you or at least give you clues as to how to solve your problem
http://p2p.wrox.com/topic.asp?TOPIC_ID=15542
Please note this was posted by Chris Büttner in another part of the forum
in http://www.sqlservercentral.com/Forums/Topic532487-1042-1.aspx
Viewing 9 posts - 1 through 8 (of 8 total)
You must be logged in to reply to this topic. Login to reply