从C#向Oracle存储过程传递数组

8
我正在尝试将数组传递给Oracle过程。我查找了相关信息,首先创建了一个名为“dizi”的类型(例如在这里enter link description here)。所以它在Oracle开发人员中可以工作。问题是; 我无法将我的C#数组作为参数传递给过程。那么我该如何将我的数组传递给我的过程呢?
以下是我的代码(当我执行时,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 Kamboj
但是它不起作用? - Flardryn
有什么错误吗?你能检查一下ODP.Net示例吗? - Mrinal Kamboj
我认为你错过了 arry.Size = quest_areas.Length; - Wernfried Domscheit
@WernfriedDomscheit 不起作用。错误是:并非所有变量都绑定。 - Flardryn
显示剩余2条评论
1个回答

16
  1. 定义一个数组类型和一个过程:

  2. CREATE or replace PACKAGE Testpackage AS 
      TYPE Areas_t is table of VARCHAR(100) index by BINARY_INTEGER;
      PROCEDURE TESTPROCEDURE(Areas IN Areas_t);       
    END Testpackage; 
    
  3. C#例程:

    public void InsertQuestion(IEnumerable<string> area_list)
    {
        var connect = new OracleConnection("YOUR CONNECTION STRING");
    
        var command = new OracleCommand("BEGIN Testpackage.Testprocedure(:Areas); END;", connect);
    
        connect.Open();
    
        var arry = command.Parameters.Add("Areas", OracleDbType.Varchar2);
    
        arry.Direction = ParameterDirection.Input;
        arry.CollectionType = OracleCollectionType.PLSQLAssociativeArray;
        arry.Value = area_list.ToArray();
        arry.Size = area_list.Count();
        arry.ArrayBindSize = area_list.Select(_ => _.Length).ToArray();
        arry.ArrayBindStatus = Enumerable.Repeat(OracleParameterStatus.Success, area_list.Count()).ToArray();
    
        command.ExecuteNonQuery();
    
        connect.Close();
    }
    

1
您是否可以友好地丰富一下这个示例,以展示如何在TESTPROCEDURE的实现中使用“区域”?提前感谢您。 - XDS
似乎您不需要像Size、Direction、ArrayBindSize、ArrayBindStatus这样的一堆参数? - Toolkit
附注:使用 IEnumerable.ToArray() 方法需要引用 System.Linq 命名空间。 - cdonner

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