考虑我的Item对象具有以下结构
Name Parent Item Name
Service 1
Stock 1 Service 1
Stock 2
[增订]:
因此,如果某个项目具有父项目名称,则它将成为子项目。我想验证所有父项名称是否为有效的Names值。例如,在示例数据中,库存1被视为子项,因为它将服务1作为父项目,服务1是有效的项目名称,因为它已经存在于名称中我已尝试执行以下操作,但这样做不返回结果:
var aa = from item in items
join
item2 in items
on item.Name equals item2.ParentRef.Value.ToString()
select new { item.Name };
答案 0 :(得分:2)
为了使其更具可读性,这里有2个查询:
var listOfNames = items.Select(t => t.Name);
var answers = items.Where(item => i.ParentItemName != null &&
!listOfItems.Contains(i.ParentItemName));
答案会为您提供无效项目列表。
答案 1 :(得分:1)
这应该返回Join
所期望的项目列表items.Select(x=>items
.select(y=> {
if(x.Name == y.ParentName)
return y;
else
return null;
})
).Where(x=>x!=null)