如何以编程方式过滤数据表

问题描述 投票:1回答:1

我需要解决一个非常简单的过滤器问题,但是我是使用DataTables,DataRows等的新手。我提出的解决方案闻起来很多。我很确定这是实现它的更好方法。

这里是解释的简单问题:

我有两个分别称为brancheschangesets的数据表。名为branches的dataTable具有系统中的所有条目,我需要过滤变更集条目中未引用的那些分支。变更集引用了名为FIDBRANCH的字段中的分支。

例如。假设一个dateTable有6个分支和3个变更集。仅引用ID为4和5的分支。

BRANCHES  
1         
2         
3
4
5
6

CHANGESETS
references to branch 4
references to branch 5
references to branch 5

结果将是仅过滤具有分支4和5的分支数据集。

这是我的坏方法:

private void FilterUnusedBranches(DataTable branches, DataTable changesets)
{
        // index referenced branch ids
        ArrayList branchIds = new ArrayList();

        foreach (DataRow row in changesets.Rows)
        {
            long id = Convert.ToInt64(row["FIDBRANCH"]);
            branchIds.Add(id);
        }

        IList<DataRow> notNeededRows = new List<DataRow>();

        // get a list of non-referenced rows
        foreach (DataRow row in branches.Rows)
        {
            long id = Convert.ToInt64(row["BRID"]);

            if (!branchIds.Contains(id))
            {
                notNeededRows.Add(row);
            }
        }

        // remove not needed rows
        foreach (DataRow row in notNeededRows)
        {
            branches.Rows.Remove(row);
        }
}
.net sql datatable dataset datarow
1个回答
0
投票

您希望在两个数据表之间创建一个DataRelation。

这可能会帮助您... http://social.msdn.microsoft.com/Forums/en/adodotnetdataproviders/thread/f122d7f4-3b7d-4d93-bd0f-8bb57cd990a4

© www.soinside.com 2019 - 2024. All rights reserved.