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'.仅支持初始值设定项,实体成员和实体导航属性.
我怎么能绕过这个?
在您的情况下,您可以简单地更改Where为使用计算属性的两个部分:
return persons.Where(p => (p.FirstName + " " + p.LastName).Contains("blah"))
Run Code Online (Sandbox Code Playgroud)