如何对DataTable中的分层数据进行自引用选择?

发布于 2024-12-12 10:47:02 字数 238 浏览 0 评论 0原文

我有一个 DataTable,其中包含两列:ReportId 和 ParentReportId。我想选择其父级尚未在数据表中列出的所有报告。我想做这样的事情(取自 SQL 语法),但我知道这行不通:

DataRow[] foo = drParentRow = dt.Select("ParentReportId NOT IN(ReportId)");

在这种情况下如何从该数据集中获取这些记录?

I have a DataTable with, let's say, two columns: ReportId and ParentReportId. I want to select all of the reports whose Parent is NOT already listed in the DataTable. I want to do something like this (taking from SQL syntax), but I know this doesn't work:

DataRow[] foo = drParentRow = dt.Select("ParentReportId NOT IN(ReportId)");

How can I get these records from this dataset in this situation?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

沦落红尘 2024-12-19 10:47:02
var noParents = dt.AsEnumerable().Where(x => x["ReportParentID"] != DBNull.Value && 
                                      !dt.rows.Any(y => y["ReportID"] == x["ReportParentID"]);
var noParents = dt.AsEnumerable().Where(x => x["ReportParentID"] != DBNull.Value && 
                                      !dt.rows.Any(y => y["ReportID"] == x["ReportParentID"]);
漫雪独思 2024-12-19 10:47:02

我认为你将不得不使用一些 LINQ 来实现这一点:

var reportIds = dt.AsEnumerable().Select(row => row.Field<int>("ReportId"));

var foo = from row in dt.AsEnumerable()
          let parentReportId = row.Field<int>("ParentReportId")
          where !reportIds.Contains(parentReportId)
          select row;

I think you're going to have to use some LINQ for this:

var reportIds = dt.AsEnumerable().Select(row => row.Field<int>("ReportId"));

var foo = from row in dt.AsEnumerable()
          let parentReportId = row.Field<int>("ParentReportId")
          where !reportIds.Contains(parentReportId)
          select row;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文