微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – Linq lambda表达式中的布尔短路评估

我有以下 Linq lambda表达式:
private IEnumerable<SubjectSelectorSubjectGroup> GetSubjectList()
{
    User user = db.Users.Find(WebSecurity.CurrentUserId);
    return db.requiredSubjects.Where(r => !r.Subject.Name.Contains("Home"))
                              .GroupBy(r => r.Subject)
                              .OrderByDescending(r => r.Count())
                              .Select(r => new SubjectSelectorSubjectGroup()
                              {
                                  SubjectId = r.Key.SubjectId,SubjectName = r.Key.Name,IsInFavourites = HttpContext.Current.Request.IsAuthenticated &&
                                                  (user.Elective1 != null && user.Elective1.SubjectId == r.Key.SubjectId ||
                                                   user.Elective2 != null && user.Elective2.SubjectId == r.Key.SubjectId ||
                                                   user.Elective3 != null && user.Elective3.SubjectId == r.Key.SubjectId),Occurrences = r.Count()
                              });
}

用户登录时,此函数中的用户变量为null.这不应该是一个问题,因为短路布尔评估应该处理这个问题.问题是,它没有!而是抛出System.NullReferenceException.

用户为null时,HttpContext.Current.Request.IsAuthenticated返回false.我通过注释引用用户变量的括号部分来检查这一点,然后表达式正确评估.

有谁知道为什么Linq to sql在这种情况下试图取消引用用户变量时它实际上不应该是必要的?有没有人解决这个问题?

解决方法

整个表达式被翻译为sql并进行评估,这意味着&&操作符没有按预期短路.

您可以通过构建要搜索的ElectiveX.SubjectId的列表或数组来解决问题,然后在查询中使用tmpList.Contains(r.Key.SubjectId).这将被转换为WHERE IN(…)sql表达式.

原文地址:https://www.jb51.cc/csharp/92309.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐