按计算属性搜索对象列表

use*_*939 5 c# linq linq-to-entities list where

这是我的班级:

public class Person
{
  public string FirstName { get; set; }
  public string LastName { get; set; }
  public string FullName { get { return FirstName + " " + LastName; } }
}
Run Code Online (Sandbox Code Playgroud)

这是我的清单:

var persons = new List<Person>();
persons.Add(...);
persons.Add(...);
etc.
Run Code Online (Sandbox Code Playgroud)

如果我尝试通过"计算"属性FullName搜索列表,如下所示:

return persons.Where(p => p.FullName.Contains("blah")) 
Run Code Online (Sandbox Code Playgroud)

我收到以下错误:

System.NotSupportedException:LINQ to Entities中不支持指定的类型成员'FullName'.仅支持初始值设定项,实体成员和实体导航属性.

我怎么能绕过这个?

Jon*_*n B 1

在您的情况下,您可以简单地更改Where为使用计算属性的两个部分:

return persons.Where(p => (p.FirstName + " " + p.LastName).Contains("blah")) 
Run Code Online (Sandbox Code Playgroud)