1

C#からオラクル関数を実行したい。私は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; 
4

2 に答える 2

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);
于 2013-08-23T07:35:23.540 に答える