Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/334.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 在EntityFramework中执行Oracle存储过程_C#_Sql_Oracle_Entity Framework - Fatal编程技术网

C# 在EntityFramework中执行Oracle存储过程

C# 在EntityFramework中执行Oracle存储过程,c#,sql,oracle,entity-framework,C#,Sql,Oracle,Entity Framework,长话短说:我正在尝试在Entity Framework中运行Oracle存储过程(我知道这听起来很奇怪,但在一般应用程序中使用Entity Framework,但由于修改key值的限制,EF无法处理此特定命令) 过程有一些参数(仅在中)并更新表中的值。我通过运行以下程序对其进行了测试: execute PROCEDURE_NAME('parameter1', parameter2 etc.); 它很好用 我的参数定义如下: OracleParameter param1 = new Oracle

长话短说:我正在尝试在Entity Framework中运行Oracle存储过程(我知道这听起来很奇怪,但在一般应用程序中使用Entity Framework,但由于修改key值的限制,EF无法处理此特定命令)

过程有一些参数(仅在中)并更新表中的值。我通过运行以下程序对其进行了测试:

execute PROCEDURE_NAME('parameter1', parameter2 etc.);
它很好用

我的参数定义如下:

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

object[] parameters = new object[] { 
                param1,...};
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();
我的问题是:

string query = "execute PROCEDURE_NAME(:PARAM1,...);";
我试图从C代码执行它。即通过运行:

_context.Database.ExecuteSqlCommand(query, parameters);
我收到错误ORA-00900:原因:该语句未被识别为有效的SQL语句。如果未安装过程选项,并且发出需要此选项的SQL语句(例如,CREATE PROCEDURE语句),则可能发生此错误。您可以通过启动SQL*Plus来确定是否安装了过程选项。如果未显示PL/SQL横幅,则不安装该选项

我认为缺少过程选项不能成为原因,因为在控制台中创建和运行过程是有效的

不幸的是,我的工具没有提供分析器,所以我无法捕获实体框架生成的查询。是否有其他方法获取已执行的查询?或者您可能会看到我的代码有任何问题?

请尝试以下查询字符串:

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

我找到了一个解决方案,如下所示:

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

object[] parameters = new object[] { 
                param1,...};
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();
过程本身显然存储在数据库中

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

context.Database.ExecuteSqlCommand("BEGIN  STORED_PROCEDURE_NAME; END; "); 
这个决心