是否可以在 LINQ 查询中检查空值,并且当该值为空时,它是否可以一次执行额外的(子)查询?
解释
我在我的数据库中声明了默认按钮,并带有默认说明。用户可以自定义这些按钮,并且这些设置存储在ButtonLocations
表格中。现在,每个按钮都有一个标准的描述,用户可以编辑这个描述。当用户编辑描述时,它存储在Descriptions
我数据库的表中。当我检索所有按钮时,我首先检查按钮是否具有特定描述(在buttonlocations中,带有左连接)。如果这不是真的(所以为空),我会检索默认描述。
目前我得到了我所有的实体及其描述,然后我遍历所有实体以检查值是否为空。这会导致对数据库的多次查询。
var temp = (from bl in context.buttonLocations
join b in context.Buttons
on bl.ButtonID equals b.ButtonID into buttons
from button in buttons.DefaultIfEmpty()
join d in context.Descriptions
on new
{
ID = bl.ButtonLocationID,
langID = languageID,
originID = descriptionOriginID
}
equals new
{
ID = d.ValueID,
langID = d.LanguageID,
originID = d.DescriptionOriginID
}
into other
where bl.ButtonGroupID == buttonGroupId
from x in other.DefaultIfEmpty()
select new
{
Button = button,
ButtonLocation = bl,
Description = x
}).ToList();
// Retrieve default descriptions if no specific one is set
foreach (var item in temp)
{
if (item.Description == null)
{
item.Description = context.Descriptions
.FirstOrDefault(x => x.ValueID == item.Button.ButtonID && x.LanguageID == languageID && x.DescriptionOriginID == (short)DescriptionOriginEnum.Button);
}
}