Динамические запросы Linq для экранов поиска пользователей - PullRequest
2 голосов
/ 04 апреля 2011

У меня есть база данных, которая имеет экран поиска пользователя, который является «динамическим», в котором я могу добавить дополнительные критерии поиска на лету, основываясь на том, какие столбцы доступны в конкретном представлении, на котором основан поиск, и это позволит пользователю использовать их немедленно. Ранее я использовал nettiers для этой базы данных, но теперь я программирую новое приложение для нее, используя RIA и EntFramework 4 и LINQ.

В настоящее время у меня есть две таблицы, которые заполняют комбинированный список доступными шаблонами строки поиска:

LastName Фамилия Имя Телефон и т.д ....

тогда у меня есть другая таблица, которая разделяет эти критерии и используется в моих алгоритмах неттье. Он хорошо работает, но я хочу использовать LINQ .. и он не очень подходит для этой модели. Кроме того, я думаю, что могу сократить это до одного стола с linq ...

используя формат, подобный этому или что-то очень близкое ...

Критерии удостоверения личности WhereClause 1 Фамилия 'Фамилия нравится'% {0}% '

теперь я знаю, что это не вписывается конкретно в запрос linq ... но я пытаюсь использовать универсальный синтаксис для ясности здесь ...

реальное условие where будет выглядеть примерно так: a => a.LastName.Contains ("{0}")

Мой первый вопрос: это вообще возможно? Вставить лямбду в строку и использовать ее в запросе Linq?

Мой второй вопрос: в какой-то момент, когда я исследовал это, я обнаружил синтаксис linq с таким префиксом, как it.LastName {0} и я, кажется, пытался использовать его, потому что его остатки все еще находятся в моих тестовых базах данных ... но я не знаю, как вспомнить, где я читал об этом.

Кто-нибудь делает это? Я провел несколько поисков и обнаружил похожие происшествия, но в большинстве случаев они имеют статические поля, которые являются необязательными, не совсем так, как я это делаю ...

Ответы [ 2 ]

1 голос
/ 04 апреля 2011

Я не уверен, насколько подробным должен быть ваш динамический запрос, но когда мне нужно выполнить динамические запросы, я создаю класс для представления значений фильтра. Затем я передаю этот класс методу поиска в моем хранилище. Если значение для поля равно нулю, запрос игнорирует его. Если он имеет значение, он добавляет соответствующий фильтр.

public class CustomerSearchCriteria{
    public string LastName { get; set; }
    public string FirstName { get; set; }
    public string PhoneName { get; set; }
}


public IEnumberable<Customer> Search(CustomerSearchCriteria criteria){
    var q = db.Customers();

    if(criteria.FirstName != null){
        q = q.Where(c=>c.FirstName.Contains(criteria.FirstName));
    }

    if(criteria.LastName!= null){
        q = q.Where(c=>c.LastName.Contains(criteria.LastName));
    }

    if(criteria.Phone!= null){
        q = q.Where(c=>c.Phone.Contains(criteria.Phone));
    }
    return q.AsEnumerable();
}
1 голос
/ 04 апреля 2011

Что касается вашего первого вопроса, вы можете сделать это, используя Dynamic Linq, как описано Скоттом Гу здесь

var query = Northwind.Products.Where("Lastname LIKE "test%");
...