Lambda与LINQ-"表达始终是假的"

She*_*vek 9 c# linq resharper lambda entity-framework

我有以下代码:

var thing = (from t in things
             where t.Type == 1 && t.IsActive
             select t).SingleOrDefault();

if (thing == null)
{
    // throw exception
}
Run Code Online (Sandbox Code Playgroud)

things 是实体框架自我跟踪实体的集合

这很好用,但是我想使用Lambda表达式并将LINQ更改为:

var thing = things.Select(t => t.Type == 1 && t.IsActive).SingleOrDefault();
Run Code Online (Sandbox Code Playgroud)

现在ReSharper的是告诉我Expression is always false(thing == null).

我错过了什么?

Jac*_*ope 15

你要:

var thing = things.Where(t => t.Type == 1 && t.IsActive).SingleOrDefault();
Run Code Online (Sandbox Code Playgroud)

Select进行投影(从转换了IEnumerable的类型IEnumerable<Thing>,以IEnumerable<bool>与值true如果t.Type == 1 && t.IsActive == true,否则false),则SingleOrDefault返回要么仅bool在该序列中,或一个默认值bool,其是false如果序列是空的.这永远不能为null,因为bool它不是引用类型.

Where执行过滤操作(仅提取满足给定标准的那些对象 - 在这种情况下仅选择Typeis 1IsActiveis的那些对象true),将IEnumerable的类型保留为IEnumerable<Thing>.假设Thing是一个类,SingleOrDefault它将返回序列中唯一的项目或null.

在任何一种情况下,SingleOrDefault如果序列包含多个项目(在Select版本中更有可能!),将抛出异常.