使用 LINQ 按孙子过滤列表
Filter list by grandchild using LINQ
我需要通过 DamageCode class 中的 DamageCodeName 字段过滤列表。
public partial class DamageCategory
{
public string DamageCategoryId { get; set; }
public string CategoryName { get; set; }
}
public partial class DamageGroup
{
public string DamageGroupId { get; set; }
public string DamageCategoryId { get; set; }
public string GroupName { get; set; }
}
public partial class DamageCode
{
public string DamageCodeId { get; set; }
public string DamageGroupId { get; set; }
public string DamageCodeName { get; set; }
}
我使用 EF CORE 5 将记录拉入列表:
private List<DamageCategory> _DamageCodeList { get; set; } = new();
_DamageCodeList = _contextDB.DamageCategories
.Include(i => i.DamageGroups)
.ThenInclude(d => d.DamageCodes).AsSingleQuery().ToListAsync();
现在我需要按 DamageCode.DamageCodeName 属性.
过滤此列表
private string _SearchText { get; set; } = "Bubble";
private List<DamageCategory> _CategoryList { get; set; } = new();
_CategoryList = _DamageCodeList.Where(g => g.DamageGroups.SelectMany(c => c.DamageCodes
.Where(w => w.DamageCodeName.ToLower().Contains(_SearchText.ToLower()))).Any()).ToList();
上面的代码只过滤 DamageCategory。它带回 DamageGroup 的所有记录和 DamageCodes 的所有记录。
我需要 linq 查询结果来生成如下所示的列表(由“Bubble”过滤)并仅带回由 DamageCode.DamageCodeName.Contains(“Bubble”过滤的 DamageCategory、DamageGroup 和 DamageCodes ):
这里是 SQL 生成的结果高于我需要的结果:
SELECT
CT.[DamageCategoryID],
CT.[CategoryName],
DG.[DamageGroupID],
DG.[DamageCategoryID],
DG.[GroupName],
DC.[DamageCodeID],
DC.[DamageGroupID],
DC.[DamageCodeName]
FROM
[dbo].[DamageCategory] AS CT
INNER JOIN [dbo].[DamageGroup] AS DG ON CT.[DamageCategoryID] = DG.[DamageCategoryID]
INNER JOIN [dbo].[DamageCode] AS DC ON DG.[DamageGroupID] = DC.[DamageGroupID]
WHERE
DC.[DamageCodeName] LIKE '%Bubble%'
这是查询语法的亮点。
from dc in _contextDB.DamageCategories
from dg in dc.DamageGroups
from dc in dg.DamageCodes
where dc.DamageCodeName.Contains("Bubble")
select new
{
dc.DamageCategoryID,
dc.CategoryName,
dg.DamageGroupID,
dg.DamageCategoryID,
dg.GroupName,
dc.DamageCodeID,
dc.DamageGroupID,
dc.DamageCodeName
}
查询形状 from ... from
是等同于 SelectMany
的查询语法。
您在代码中使用了 ToLower
。那可能没有必要。查询被翻译成 SQL 并且如果数据库字段具有不区分大小写的排序规则,则不需要 ToLower
.
我需要通过 DamageCode class 中的 DamageCodeName 字段过滤列表。
public partial class DamageCategory
{
public string DamageCategoryId { get; set; }
public string CategoryName { get; set; }
}
public partial class DamageGroup
{
public string DamageGroupId { get; set; }
public string DamageCategoryId { get; set; }
public string GroupName { get; set; }
}
public partial class DamageCode
{
public string DamageCodeId { get; set; }
public string DamageGroupId { get; set; }
public string DamageCodeName { get; set; }
}
我使用 EF CORE 5 将记录拉入列表:
private List<DamageCategory> _DamageCodeList { get; set; } = new();
_DamageCodeList = _contextDB.DamageCategories
.Include(i => i.DamageGroups)
.ThenInclude(d => d.DamageCodes).AsSingleQuery().ToListAsync();
现在我需要按 DamageCode.DamageCodeName 属性.
过滤此列表private string _SearchText { get; set; } = "Bubble";
private List<DamageCategory> _CategoryList { get; set; } = new();
_CategoryList = _DamageCodeList.Where(g => g.DamageGroups.SelectMany(c => c.DamageCodes
.Where(w => w.DamageCodeName.ToLower().Contains(_SearchText.ToLower()))).Any()).ToList();
上面的代码只过滤 DamageCategory。它带回 DamageGroup 的所有记录和 DamageCodes 的所有记录。
我需要 linq 查询结果来生成如下所示的列表(由“Bubble”过滤)并仅带回由 DamageCode.DamageCodeName.Contains(“Bubble”过滤的 DamageCategory、DamageGroup 和 DamageCodes ):
这里是 SQL 生成的结果高于我需要的结果:
SELECT
CT.[DamageCategoryID],
CT.[CategoryName],
DG.[DamageGroupID],
DG.[DamageCategoryID],
DG.[GroupName],
DC.[DamageCodeID],
DC.[DamageGroupID],
DC.[DamageCodeName]
FROM
[dbo].[DamageCategory] AS CT
INNER JOIN [dbo].[DamageGroup] AS DG ON CT.[DamageCategoryID] = DG.[DamageCategoryID]
INNER JOIN [dbo].[DamageCode] AS DC ON DG.[DamageGroupID] = DC.[DamageGroupID]
WHERE
DC.[DamageCodeName] LIKE '%Bubble%'
这是查询语法的亮点。
from dc in _contextDB.DamageCategories
from dg in dc.DamageGroups
from dc in dg.DamageCodes
where dc.DamageCodeName.Contains("Bubble")
select new
{
dc.DamageCategoryID,
dc.CategoryName,
dg.DamageGroupID,
dg.DamageCategoryID,
dg.GroupName,
dc.DamageCodeID,
dc.DamageGroupID,
dc.DamageCodeName
}
查询形状 from ... from
是等同于 SelectMany
的查询语法。
您在代码中使用了 ToLower
。那可能没有必要。查询被翻译成 SQL 并且如果数据库字段具有不区分大小写的排序规则,则不需要 ToLower
.