Установите PredicateBuilder также в дочерней коллекции - PullRequest
0 голосов
/ 09 декабря 2018

Я пытаюсь применить предикат не только к родительскому объекту, но и к дочерней коллекции.Следующее является частью моего кода:

var predicate = PredicateBuilder.New<Entity>();
foreach (string keyword in keywords)
{
    string temp = keyword;
    predicate = predicate.Or(p => p.Name.Equals(temp));
    predicate = predicate.Or(p => p.Addresses.Select(x=> x.Name.Equals(temp));
}

Линия predicate = predicate.Or(p => p.Addresses.Select(x=> x.Name.Equals(temp)); не работает?есть идеи, почему?

РЕДАКТИРОВАТЬ

В следующей демонстрации я прошу получить сущность parent и child с name = tom, но я также получаю child name = tom2.

private static void Main(string[] args)
{
    var result = GetAll(GetAll(), new List<string> { "tom" });
}

private static List<User> GetAll()
{
    return new List<User>
    {
        new User
        {
            Id = 1,
            Name = "tom",
            Addesses = new List<Addesses>
            {
                    new Addesses { Id = 1, Name = "tom" },
                    new Addesses { Id = 1, Name = "tom2" },
            }
        },
            new User
        {
            Id = 1,
            Name = "sam",
            Addesses = new List<Addesses>
            {
                    new Addesses { Id = 1, Name = "sam" },
                    new Addesses { Id = 1, Name = "sam2" },
            }
        },
    };
}

private static List<User> GetAll(List<User> users, List<string> keywords)
{
    var predicate = PredicateBuilder.New<User>();

    foreach (string keyword in keywords)
    {
        string temp = keyword;
        predicate = predicate.Or(p => p.Name.Equals(temp));
        predicate = predicate.Or(p => p.Addesses.Any(x => x.Name.Equals(temp)));
    }

    var result = users
        .Where(predicate)
        .ToList();

    return result;
}

public class User
{
    public int Id { get; set; }
    public string Name { get; set; }
    public List<Addesses> Addesses { get; set; }
}

public class Addesses
{
    public int Id { get; set; }
    public string Name { get; set; }
}

1 Ответ

0 голосов
/ 09 декабря 2018

Вызов p.Addresses.Select(x=> x.Name.Equals(temp) не возвращает логический результат.

В зависимости от вашей реальной логики вы можете посмотреть Any:

predicate = predicate.Or(p => p.Addresses.Any(x=> x.Name.Equals(temp));

или All:

predicate = predicate.Or(p => p.Addresses.All(x=> x.Name.Equals(temp));
...