Lan*_*eyo 4 c# sql oracle entity-framework
简而言之:我正在尝试在Entity Framework中运行Oracle存储过程(我知道这听起来很奇怪但是在一般应用程序中使用Entity Framework但由于修改密钥的限制而无法由EF处理此特定命令值).
过程有一些参数(仅IN)并更新表中的值.我通过运行测试它:
execute PROCEDURE_NAME('parameter1', parameter2 etc.);
Run Code Online (Sandbox Code Playgroud)
它工作正常.
我的参数定义如下:
OracleParameter param1 = new OracleParameter("PARAM1", OracleDbType.Varchar2, changed.PARAM1, ParameterDirection.Input);
object[] parameters = new object[] {
param1,...};
Run Code Online (Sandbox Code Playgroud)
我的查询是:
string query = "execute PROCEDURE_NAME(:PARAM1,...);";
Run Code Online (Sandbox Code Playgroud)
我正在尝试从C#代码执行它.即通过运行:
_context.Database.ExecuteSqlCommand(query, parameters);
Run Code Online (Sandbox Code Playgroud)
我收到错误ORA-00900:原因:该语句未被识别为有效的SQL语句.如果未安装过程选项并且发出了需要此选项的SQL语句(例如,CREATE PROCEDURE语句),则会发生此错误.您可以通过启动SQL*Plus来确定是否安装了Procedural选项.如果未显示PL/SQL横幅,则表示未安装该选项.
我认为缺乏过程选项不能成为一个原因,因为在控制台中创建和运行过程是有效的.
不幸的是我的工具不提供分析器,所以我无法捕获Entity Framework生成的查询.有没有其他方法来获取执行的查询?或者你可以看到我的代码有任何问题?
小智 6
Try this query string:
string query = "begin PROCEDURE_NAME(:PARAM1,...); end; ";
Run Code Online (Sandbox Code Playgroud)
我找到了一个解决方案,如下所示:
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();
Run Code Online (Sandbox Code Playgroud)
过程本身显然存储在数据库中。
| 归档时间: |
|
| 查看次数: |
5161 次 |
| 最近记录: |