私はこれを持っています:
public class Company
{
public int Id { get; set; }
public string Name { get; set; }
}
public class City
{
public int Id { get; set; }
public string Name { get; set; }
public int ZipCode { get; set; }
}
public class Person
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public int? Age { get; set; }
public City City { get; set; }
public Company Company { get; set; }
}
場合によっては、次のような述語を生成してください。
var result = listPerson.Where(x => x.Age == 10).ToList<>();
またはこれ:
var result = listPerson.Where( x => x.Company.Name == 1234).ToList();
またはこれ:
var result = listPerson.Where( x => x.City.ZipCode == "MyZipCode").ToList();
またはこれ:
var result = listPerson.Where( x => x.Company.Name == "MyCompanyName").ToList();
次に、「PredicateBuilder」を作成しました。これを行うと、それが機能します(null可能かどうかに関係なく型を取得し、述語を作成します):
BuildPredicate<Person>("Age", 10); I get this : x => x.Age == 10
しかし、次のようなネストされたプロパティがある場合、私はどのように管理しません:
BuildPredicate<Person>("City.ZipCode", "MyZipCode");
I'd like get this : x => x.City.ZipCode == "MyZipCode"
またはこれ:
BuildPredicate<Person>("City.Name", "MyName");
I'd like get this : x => x.City.Name == "MyName"
またはこれ:
BuildPredicate<Person>("Company.Name", "MyCompanyName");
I'd like get this : x => x.Company.Name == "MyCompanyName"