如果您正在使用Entity Framework 4.1 Code First,可以尝试使用
Database.SqlQuery方法。例如,对于此函数。
CREATE OR REPLACE FUNCTION USERNAME_CTX.FUNCTION1 (param number)
RETURN number
AS
BEGIN
return param + 1;
END;
你可以使用这段代码:
using (var ctx = new Model()) {
var result = ctx.Database.SqlQuery<int>("select username_ctx.FUNCTION1(:p0) from dual",1).FirstOrDefault();
}
编辑:
请注意,这是针对dotConnect for Oracle的解决方案(也许对于实现类似解决方案的ODP.NET有用)
对于此函数:
CREATE OR REPLACE FUNCTION USERNAME_CTX.FUNCTION2 (param number, int_param out number, str_param out varchar2)
RETURN number
AS
BEGIN
int_param := param + 2;
str_param := 'value';
return param + 1;
END;
你可以使用以下代码:
using (var ctx = new Model()) ; int_param: ; str_param: '{2}'", result, secondParam.Value, thirdParam.Value);
}
编辑2
或使用此代码:
using (var ctx = new Model()) {
var firstParam = new Devart.Data.Oracle.OracleParameter("p0", OracleDbType.Number, 1, ParameterDirection.Input);
var secondParam = new Devart.Data.Oracle.OracleParameter("p1", OracleDbType.Number, ParameterDirection.Output);
var thirdParam = new Devart.Data.Oracle.OracleParameter("p2", OracleDbType.VarChar, ParameterDirection.Output);
var resultParam = new Devart.Data.Oracle.OracleParameter("res", OracleDbType.Number, 1, ParameterDirection.Output);
ctx.Database.ExecuteSqlCommand(@"begin :res := username_ctx.FUNCTION2(:p0, :p1, :p2); end;", firstParam, secondParam, thirdParam, resultParam);
Console.WriteLine("Return value: {0}; int_param: {1}; str_param: '{2}'", resultParam.Value, secondParam.Value, thirdParam.Value);
}
OUT
参数,那么它将不起作用。:(
- gdoronDevart.Data.Oracle
命名空间位于哪里? - gdoronDevart.Data.Oracle
提供程序调用oracle package
? - Amir