如何使用实体框架在 oracle 包中调用存储过程?

Posted

技术标签:

【中文标题】如何使用实体框架在 oracle 包中调用存储过程?【英文标题】:How to call a Stored Procedure inside an oracle package with Entity Framework? 【发布时间】:2014-03-24 19:23:13 【问题描述】:

我在 oracle 11g 中有一个包如下:

CREATE OR REPLACE PACKAGE "HRS.PKG_TRAINING_SP" as
TYPE T_CURSOR IS REF CURSOR;

procedure GETPERSONNELTRAINIGLIST(
        personnel_Id_in in string,
        base_date_in in string,
        is_current_in in number,
        lst OUT T_CURSOR );
end;

如何使用实体框架(代码优先)执行上述程序包(GETPERSONNELTRAINIGLIST)?

注意:我正在为 Oracle 使用实体框架 6.0(代码优先)和 devart EF Provider

更新: 我正在使用以下代码:

var param1 = new OracleParameter("personnel_Id_in", OracleDbType.VarChar, "c5eb5589-8fee-47b6-85ad-261a0307cc16", ParameterDirection.Input);
var param2 = new OracleParameter("base_date_in", OracleDbType.VarChar, "1112", ParameterDirection.Input);
var param3 = new OracleParameter("is_current_in", OracleDbType.Number, 1, ParameterDirection.Input);

var ATests =
    db.Database.SqlQuery<ATest>(
    "BEGIN PKG_TRAINING_SP.GETPERSONNELTRAINIGLIST(:personnel_Id_in, :base_date_in, :is_current_in); end;", 
    param1,  param2, param3).ToList();

但出现以下错误:

"ORA-06550: line 1, column 7:\nPLS-00306: wrong number or types of arguments in call to 'GETPERSONNELTRAINIGLIST'\nORA-06550: line 1, column 7:\nPL/SQL: Statement ignored"

【问题讨论】:

【参考方案1】:

请按以下方式重写您的代码:

var param1 = new OracleParameter("personnel_Id_in", OracleDbType.VarChar, "c5eb5589-8fee-47b6-85ad-261a0307cc16",  ParameterDirection.Input);
var param2 = new OracleParameter("base_date_in", OracleDbType.VarChar, "1112", ParameterDirection.Input);
var param3 = new OracleParameter("is_current_in", OracleDbType.Number, 1, ParameterDirection.Input);
var param4 = new OracleParameter("result", OracleDbType.Cursor, ParameterDirection.Output);

var ATests =
db.Database.SqlQuery<ATest>(
"BEGIN PKG_TRAINING_SP.GETPERSONNELTRAINIGLIST(:personnel_Id_in, :base_date_in, :is_current_in, :result); end;", 
param1,  param2, param3, param4).ToList();

另外,我们已经在我们的论坛http://forums.devart.com/viewtopic.php?t=29019与您联系

【讨论】:

执行包中所有程序的最佳做法是什么? 当使用 Code-First 方法时,我们上面描述的方法(通过 SqlQuery 方法 msdn.microsoft.com/en-us/library/gg679117%28v=vs.103%29.aspx )是最合适的。有关使用存储过程创建 EF 模型并使用它们的一般信息,请参见devart.com/dotconnect/oracle/docs/?OracleRoutines.html @Devart 你能帮忙看看这个问题吗,非常感谢。 ***.com/questions/23236071【参考方案2】:

您没有指定游标变量。

lst OUT T_CURSOR

这就是你有错误的原因。

您可以从这里possible answer 尝试解决方案。

【讨论】:

如何将lst 参数放入db.Database.SqlQuery this 不能提供帮助吗?关于ref cursor,但我认为制作它没有真正的问题吗?

以上是关于如何使用实体框架在 oracle 包中调用存储过程?的主要内容,如果未能解决你的问题,请参考以下文章

实体框架和 Oracle 客户端 - 存储过程问题

如何使用实体管理器在spring中调用oracle存储过程?

如何在实体框架中调用带有联接的存储过程?

oracle 包中定义全局变量

使用 ADO.NET 获取 Oracle 包中过程的存储过程元数据

在实体框架中使用存储过程