如何创建LINQ请求
本文关键字:LINQ 请求 创建 何创建 | 更新日期: 2023-09-27 17:59:50
我无法创建LINQ请求。我有一个基本请求:
var result = from i in _dbContext.Users
where i.ID != CurrentUserID &&
//i.UserType.UserTypeID == (from a in _dbContext.UserTypes where a.UsersSelectMeetingCriteria.Any(p => p.ID == CurrentUserID) select a.UserTypeID).FirstOrDefault() &&
i.Services.Any(p => p.UsersSelectMeetingCriteria.Any(k => k.ID == CurrentUserID)) &&
i.GeographicalAreas.Any(p=>p.UsersSelectMeetingCriteria.Any(o=>o.ID == CurrentUserID)) &&
i.MultiplyItems.Any(r => (r.UsersSelectMeetingCriteria.Any(q => q.ID == CurrentUserID) && r.ItemType == MultiplyItemKeys.USER_TYPE)) &&
i.MultiplyItems.Any(s => (s.UsersSelectMeetingCriteria.Any(q => q.ID == CurrentUserID) && s.ItemType == MultiplyItemKeys.COMPANY_INVOLVED)
)
select new DataTable.UserModel()
{ ... };
但我需要4级搜索。如果所有4个都可以,那么这是第一级用户,如果只有3个(但第4个不是)-级别#2,如果2-是,2-否,那么级别#3,如果只有一个匹配-级别#4。怎么做?
未经测试,在黑暗中进行了一次相当疯狂的尝试,但这可能会为您指明正确的方向:
var result = from i in _dbContext.Users
let check1 = i.Services.Any(p => p.UsersSelectMeetingCriteria.Any(k => k.ID == CurrentUserID))
let check2 = i.GeographicalAreas.Any(p=>p.UsersSelectMeetingCriteria.Any(o=>o.ID == CurrentUserID))
let check3 = i.MultiplyItems.Any(r => (r.UsersSelectMeetingCriteria.Any(q => q.ID == CurrentUserID) && r.ItemType == MultiplyItemKeys.USER_TYPE))
let check4 = i.MultiplyItems.Any(s => (s.UsersSelectMeetingCriteria.Any(q => q.ID == CurrentUserID) && s.ItemType == MultiplyItemKeys.COMPANY_INVOLVED))
let level = 5 - (check1 ? 1 : 0) - (check2 ? 1 : 0) - (check3 ? 1 : 0) - (check4 ? 1 : 0)
where i.ID != CurrentUserID && level <= 4
select new {i, level};
它的作用是独立执行检查,然后从5中减去成功的检查数。因此,如果三个成功,一个失败,您将获得5-3="级别2"。
注意,如果我真的走在正确的轨道上,这看起来像是一个巨大的混乱和更大的黑客攻击。我倾向于将逻辑移到存储过程中,或者尝试在数据模型中的其他地方简化它。
注意2,我也尽职尽责地忽略了您的注释代码。
注意3,如果我了解您的数据模型和查询背后的推理,我相信有更好的方法可以做到这一点。