在Linq查询中检查对象是否为空

5

如何使用LINQ查询检查对象是否为空?

如果对象为空,我希望在搜索中省略它。

我不想做一个If Else语句并复制代码,在查询之前检查对象是否为空。目前,如果对象不为空,我的查询将返回错误"可空对象必须具有值。"

public ActionResult Search(List<int> accountStatus = null , string accountName = "", int pageId = 1)
    {
        var model = Db.Entities
            .Where(i => i.GroupId == null && i.IsActive)
            .Where(an => string.IsNullOrEmpty(accountName) || (an.Name.StartsWith(accountName) || an.Name.Contains(accountName)))
            .ToList()
            .Where(accs => accountStatus == null || accountStatus.Contains((int)accs.CurrentStatusId.Value))
            .OrderByDescending(x => x.CreatedDate);    

        if (Request.IsAjaxRequest())
        {
            return PartialView("********", model.ToPagedList(pageId, nbItemsPerPage));
        }

        return View(model);
    }

1
哪一行返回了错误? - Yuval Itzchakov
1
你确实可能想要告诉哪个属性是“null”。另外,为什么在代码中间要执行 ToList - Patrick Hofman
.Where(accs => accountStatus == null || accountStatus.Contains((int)accs.CurrentStatusId.Value)) - user4884237
accountStatusnull - user4884237
1
你为什么要检查 accountStatus 是否为空 (==null)?难道你不想确保它 不是空 吗? - Yuval Itzchakov
显示剩余4条评论
1个回答

7

如果你想让所有 accsaccountStatusnull 时都能通过,请按以下方式操作:

.Where( accs => accs != null
                && ( accountStatus == null
                     || accountStatus.Contains(accs.CurrentStatusId.GetValueOrDefault(-1))
                   )
      )

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接