如何在C#中执行Oracle函数

时间:2013-08-23 07:08:31

标签: c# oracle odac

我想从c#执行oracle函数。我使用oracle数据访问OracleConnection和OracleCommand。我的功能是;

create or replace 
FUNCTION Fnc_Sistem(Tbl VarChar2) RETURN Number IS
Sistem    Number     := -1;
C         Integer;
S         Integer;

BEGIN
C := Dbms_sql.open_cursor;
Dbms_sql.parse(C, 'Select Sistem_Kodu From '||Tbl ||' Where Referans = 1', 0);
Dbms_sql.define_column(C, 1, Sistem);
S := dbms_sql.execute(C);
Loop
  If Dbms_sql.fetch_rows(C) > 0 then
       Dbms_sql.Column_value(C, 1, Sistem);
  End If;
  Exit;
End Loop;
Dbms_sql.close_cursor(C);
Return (Sistem);
Exception
      when others then
     If dbms_sql.is_open(C) then
        dbms_sql.close_cursor(C);
        Return (-1);
     end if;
     Return (-1);
     Raise;
End; 

2 个答案:

答案 0 :(得分:1)

您可以使用Oracle 匿名阻止来调用您的函数:

public static int FunctionCall(String value, String myConnectionString) {
  using (var conn = new OracleConnection(myConnectionString)) {
    conn.Open();

    using (var command = conn.CreateCommand()) {
      command.CommandText =
        @"begin
            :prm_Result := Fnc_Sistem(:prm_Argument);
          end;";

      command.Parameters.Add(":prm_Result", OracleDbType.Varchar2, ParameterDirection.Output);
      command.Parameters.Add(":prm_Argument", OracleDbType.Varchar2).Value = value;

      command.ExecuteNonQuery();

      return int.Parse(command.Parameters[0].Value.ToString());
    }
  } 
}

....

int myValue = FunctionCall("myValue", myConnectionString);

答案 1 :(得分:0)

可以使用类似于存储过程的方式来调用Oracle函数:

cmd = new OracleCommand("Fnc_Sistem", connection);
cmd.CommandType = CommandType.StoredProcedure;

cmd.Parameters.Add("prm_Result", OracleDbType.Varchar2, ParameterDirection.ReturnValue);
cmd.Parameters.Add("prm_Argument", OracleDbType.Varchar2).Value = value;

command.ExecuteNonQuery();

应该首先创建return参数,无论BindByName是true还是false,其名称都不重要。