【问题标题】:Passing array to Oracle procedure from c#从 c# 将数组传递给 Oracle 过程
【发布时间】:2017-03-09 19:37:31
【问题描述】:

我正在尝试将一个数组传递给 oracle 程序。我搜索了一下,首先我创建了一个名为“dizi”的类型(比如这里enter link description here)。所以它适用于oracle开发人员。问题是;我不能将我的 c# 数组作为参数传递给过程。那么如何将我的数组传递给我的程序呢?

这是我的代码(当我执行时,oracle 错误提示:并非所有变量都绑定)

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
  • 但是不行?
  • 什么错误,你能检查一下ODP.Net示例
  • 我想你错过了arry.Size = quest_areas.Length;
  • @MrinalKamboj 错误是:并非所有变量都绑定

标签: c# arrays oracle stored-procedures


【解决方案1】:
  1. 定义一个数组类型和一个过程:

    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; 
    
  2. 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();
    }
    

【讨论】:

  • 您能否丰富这个示例,以展示如何在 TESTPROCEDURE 的实现中使用“区域”?提前谢谢你。
  • 好像不需要Size、Direction、ArrayBindSize、ArrayBindStatus等一堆参数?
  • 旁注:IEnumerable.ToArray() 需要 System.Linq。
猜你喜欢
  • 2011-07-09
  • 1970-01-01
  • 2012-02-10
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-06-14
相关资源
最近更新 更多