【问题标题】:input array is longer than the number of columns in this table输入数组长于此表中的列数
【发布时间】:2019-03-27 15:57:27
【问题描述】:

我已经定义了一个这样的数据表

DataTable dtFinal = new DataTable();
dtFinal.Columns.Add("AVNR", typeof(int));
dtFinal.Columns.Add("Substation", typeof(string));
dtFinal.Columns.Add("ColumnTitle", typeof(string));
dtFinal.Columns.Add("S6_NAME", typeof(string));
dtFinal.Columns.Add("Voltage", typeof(string));
dtFinal.Columns.Add("Wert", typeof(decimal));

我在两个表之间进行连接以获得结果集

  var results = from table1 in dtTimeListTable.AsEnumerable()
                join table2 in readyDataTable.AsEnumerable() on (decimal)table1["Avnr"] equals (int)table2["Avnr"]
                select new
                {
                    AVNR = (int)table2["AVNR"],
                    Substation = (string)table2["Substation"],
                    ColumnTitle = (string)table2["ColumnTitle"],
                    S6_NAME = (string)table2["S6_NAME"],
                    Voltage = (string)table2["Voltage"],                                  
                    Wert = (decimal)table1["Wert"]                                   
                 };

要填充数据表,我执行以下操作:

            dtFinal.Rows.Add(results.ToArray());

但是我会得到一个错误,比如这个

输入数组长于该表的列数

两个数据表都有 6 列,可能是什么问题?

【问题讨论】:

  • dtTimeListTablereadyDataTable 中有哪些列?
  • 因为result 不是您在select 子句中声明的匿名对象,它是该匿名对象的IEnumerable。 (转换为评论,因为蒂姆更快......)

标签: c# visual-studio visual-studio-2010 datatable


【解决方案1】:

DataRowCollection.Add 是一种添加单个 DataRow 的方法,但您正在尝试添加所有行。

你需要一个循环:

foreach(var x in query)
    dtFinal.Rows.Add(x.AVNR, x.Substation, x.ColumnTitle, x.S6_NAME, x.Voltage, x.Wert);

您也可以通过这种方式为每个DataRow 构建object[]

var joinedRows = from table1 in dtTimeListTable.AsEnumerable()
                 join table2 in readyDataTable.AsEnumerable() on (decimal) table1["Avnr"] equals (int) table2["Avnr"]
                 select new { r1 = table1, r2 = table2 };

foreach (var x in joinedRows)
{
    object[] fields =
    {
        x.r2.Field<int>("AVNR"), x.r2.Field<string>("Substation"), x.r2.Field<string>("ColumnTitle"),
        x.r2.Field<int>("S6_NAME"), x.r2.Field<string>("Voltage"), x.r1.Field<decimal>("Wert"),
    };
    dtFinal.Rows.Add(fields);
}

【讨论】:

    猜你喜欢
    • 2018-08-21
    • 2017-09-03
    • 2023-03-11
    • 1970-01-01
    • 1970-01-01
    • 2015-06-02
    • 1970-01-01
    • 2016-11-19
    相关资源
    最近更新 更多