Finally, we came up with the following solution:
create or replace procedure dummy_proc (dummy1 in number, dummy2 in varchar2, dummy3 out number, dummy4 out varchar2) is begin dummy3 := 1508 + dummy1; dummy4 := 'This is just sad! -> ' || dummy2; end dummy_proc;
And its correspondent .NET call:
Entities e = new Entities();
OracleParameter o1 = new OracleParameter("dummy1", OracleDbType.Int32); OracleParameter o2 = new OracleParameter("dummy2", OracleDbType.Varchar2); OracleParameter o3 = new OracleParameter("dummy3", OracleDbType.Int32); OracleParameter o4 = new OracleParameter("dummy4", OracleDbType.Varchar2); o1.Direction = System.Data.ParameterDirection.Input; o1.Value = v; o2.Direction = System.Data.ParameterDirection.Input; o2.Value = "test"; o2.Size = 1000; o3.Direction = System.Data.ParameterDirection.Output; o4.Direction = System.Data.ParameterDirection.Output; o4.Size = 1000; e.ExecuteStoreCommand("begin dummy_proc(:dummy1, :dummy2, :dummy3, :dummy4); end;", o1, o2, o3, o4);
Additionally, you might have to add a reference to Oracle's ODAC libraries to your project.