在EntityFramework中执行Oracle存储过程

5

简而言之:我正在尝试在Entity Framework中运行Oracle存储过程(虽然这听起来很奇怪,但通常应用程序使用Entity Framework,但由于修改关键字值的限制,此特定命令无法通过EF处理)。

该存储过程具有一些参数(仅为IN),并更新表中的值。我通过运行以下命令进行了测试:

execute PROCEDURE_NAME('parameter1', parameter2 etc.);

它运行良好。

我的参数定义如下:

OracleParameter param1 = new OracleParameter("PARAM1", OracleDbType.Varchar2, changed.PARAM1, ParameterDirection.Input);

object[] parameters = new object[] { 
                param1,...};

我的查询是:

string query = "execute PROCEDURE_NAME(:PARAM1,...);";

我想从C#代码中执行它。具体地,通过运行:

_context.Database.ExecuteSqlCommand(query, parameters);

我遇到了错误 ORA-00900。原因:该语句无法被识别为有效的SQL语句。如果发出需要Procedural Option(例如CREATE PROCEDURE语句)但未安装此选项,则可能会发生此错误。您可以通过启动SQL*Plus来确定是否已安装Procedural Option。如果未显示PL/SQL横幅,则未安装该选项。
我认为缺少Procedural Option不应该是原因,因为在控制台中创建和运行存储过程可以运行。
不幸的是,我的工具不提供分析器,因此我无法捕获由Entity Framework生成的查询。是否有其他方法可以获得已执行的查询?或者您能否看到我的代码存在什么问题?
3个回答

8
尝试使用此查询字符串:

试试这个查询字符串:

string query = "begin PROCEDURE_NAME(:PARAM1,...); end; ";

4
我找到了一个解决方案,它的代码如下:
OracleConnection connection = (Oracle.DataAccess.Client.OracleConnection)_context.Database.Connection;
connection.Open();
OracleCommand cmd = _context.Database.Connection.CreateCommand() as OracleCommand;
cmd.CommandText = "STORED_PROCEDURE_NAME";
cmd.CommandType = CommandType.StoredProcedure;

#region Parameters

//original and changed are just some POCOs
OracleParameter oNameOfParameter = new OracleParameter("oNameOfParameter", OracleDbType.Decimal, original.NameOfParameter, ParameterDirection.Input);
OracleParameter oNameOfParameter2 = new OracleParameter("oNameOfParameter2", OracleDbType.Varchar2, original.NameOfParameter2, ParameterDirection.Input);

OracleParameter NameOfParameter3 = new OracleParameter("nameOfParameter3", OracleDbType.Varchar2, changed.NameOfParameter3, ParameterDirection.Input);
OracleParameter NameOfParameter4 = new OracleParameter("nameOfParameter4", OracleDbType.Decimal, changed.NameOfParameter4, ParameterDirection.Input);

cmd.Parameters.Add(nameOfParameter3);
cmd.Parameters.Add(nameOfParameter4);
cmd.Parameters.Add(oNameOfParameter);
cmd.Parameters.Add(oNameOfParameter2);

#endregion Parameters

var i = cmd.ExecuteNonQuery();
connection.Close();

过程本身显然存储在数据库中。


0
EntityERP context = new EntityERP (); // is a context map from entity

context.Database.ExecuteSqlCommand("BEGIN  STORED_PROCEDURE_NAME; END; "); 

这个解决了。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接