首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >DataRelation:如何比较特定列

DataRelation:如何比较特定列
EN

Stack Overflow用户
提问于 2019-05-28 23:04:01
回答 1查看 193关注 0票数 0

我正在使用这个链接Compare two Datatables中的答案比较两个数据表,但是当我使用DataRelation函数时,我得到一个错误,两个列的长度都应该匹配。但我只想比较特定的列。

目前我是这样做的:

代码语言:javascript
复制
// Using a Dataset to make use of a DataRelation Object
using (DataSet ds = new DataSet())
{
    //Add Tables
    ds.Tables.AddRange(new DataTable[] { dt.Copy(), dataTable.Copy() });

    //Get  First Columns for DataRelation
    DataColumn[] firstcolumns = new DataColumn[7];
    firstcolumns[0] = ds.Tables[0].Columns[0];
    firstcolumns[1] = ds.Tables[0].Columns[1];
    firstcolumns[2] = ds.Tables[0].Columns[2];
    firstcolumns[3] = ds.Tables[0].Columns[3];
    firstcolumns[4] = ds.Tables[0].Columns[4];
    firstcolumns[5] = ds.Tables[0].Columns[5];
    firstcolumns[6] = ds.Tables[0].Columns[6];

    //Get Second Columns for DataRelation
    DataColumn[] secondcolumns = new DataColumn[8];
    secondcolumns[0] = ds.Tables[1].Columns[0];
    secondcolumns[1] = ds.Tables[1].Columns[1];
    secondcolumns[2] = ds.Tables[1].Columns[2];
    secondcolumns[3] = ds.Tables[1].Columns[3];
    secondcolumns[4] = ds.Tables[1].Columns[4];
    secondcolumns[5] = ds.Tables[1].Columns[5];
    secondcolumns[6] = ds.Tables[1].Columns[6];
    secondcolumns[7] = ds.Tables[1].Columns[7];

    //Create DataRelation
    DataRelation r = new DataRelation(string.Empty, firstcolumns, secondcolumns, false);

    ds.Relations.Add(r);

    //Create Columns for return table
    for(int i = 0; i < dt.Columns.Count ; i++ )
    {
        ResultDataTable.Columns.Add(dt.Columns[i].ColumnName, dt.Columns[i].DataType);
    }

    //If first Row not in second, add to return table
    ResultDataTable.BeginLoadData();

    foreach( DataRow parentrow in ds.Tables[0].Rows)
    {
        DataRow[] childrows = parentrow.GetChildRows(r);
        if (childrows != null || childrows.Length != 0)
        {
            ResultDataTable.LoadDataRow(parentrow.ItemArray, true);
        }
    }

    ResultDataTable.EndLoadData();

    ResultDataTable.AsDataView();

    //Export to Excel
    ResultDataTable.WriteXml("data.xls");
}

我想要做的是,如果第一列中的所有列都与第二列中的列1、2、3、4、5、6、7匹配,则将所有第二列(包括0)加载到resultdatatable中

你能建议我怎么做吗?

EN

回答 1

Stack Overflow用户

发布于 2019-05-30 15:53:35

我用LINQ解决了这个问题。得到了一些关于Stackoverflow的帮助。以下是我的问题的链接:Compare datatables using LINQ

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56345111

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档