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 1和IsActiveis的那些对象true),将IEnumerable的类型保留为IEnumerable<Thing>.假设Thing是一个类,SingleOrDefault它将返回序列中唯一的项目或null.
在任何一种情况下,SingleOrDefault如果序列包含多个项目(在Select版本中更有可能!),将抛出异常.
| 归档时间: |
|
| 查看次数: |
1369 次 |
| 最近记录: |