简而言之:我正在尝试在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语句。如果未安装过程选项,并且发出要求此选项的SQL语句(例如,CREATE PROCEDURE语句),则可能发生此错误。您可以通过启动SQL * Plus来确定是否安装了过程选件。如果未显示PL / SQL标语,则未安装该选件。
我认为缺少Procedural Option不能成为原因,因为在控制台中创建和运行该过程是可行的。
不幸的是,我的工具没有提供分析器,因此我无法捕获由Entity Framework生成的查询。还有其他方法可以获取执行的查询吗?也许您可以看到我的代码有任何问题?
我找到了一个解决方案,它看起来如下:
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();
程序本身显然存储在数据库中。