我正在尝试将数组传递给Oracle过程。我查找了相关信息,首先创建了一个名为“dizi”的类型(例如在这里enter link description here)。所以它在Oracle开发人员中可以工作。问题是; 我无法将我的C#数组作为参数传递给过程。那么我该如何将我的数组传递给我的过程呢?
以下是我的代码(当我执行时,Oracle错误显示:Not all variables bound)
以下是我的代码(当我执行时,Oracle错误显示:Not all variables bound)
public void InsertQuestion(List<string> area_list)
{
quest_areas = area_list.ToArray();
command.Connection = connect;
connect.Open();
var arry = command.Parameters.Add("Areas", OracleDbType.Varchar2);
arry.Direction = ParameterDirection.Input;
arry.CollectionType = OracleCollectionType.PLSQLAssociativeArray;
arry.Value = quest_areas;
command.CommandText ="TESTPROCEDURE(:Areas)";
command.CommandType = CommandType.StoredProcedure;
command.ExecuteNonQuery();
connect.Close();
}
command.Parameters.Add
添加DbParameter
,内部是OracleParameter
。 - Mrinal Kambojarry.Size = quest_areas.Length;
。 - Wernfried Domscheit