我想从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;
答案 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,其名称都不重要。