RavenDB поиск по нескольким словам

#c# #.net #search #cloud #ravendb

Вопрос:

Я хочу выполнить поиск документов в RavenDB и сделать результаты поиска более точными для каждого искомого слова.

Это мой текущий код (упрощенный). Для каждой итерации в цикле я хочу сделать предложение и «и». Как это возможно?

На данный момент я просто получаю больше результатов для каждого слова, но я хочу получать меньше результатов за слово.

 using (var session = this.ravenSession.Store.OpenAsyncSession())
{
    var query = session.Query<TestDocument, TestIndex>();

    foreach (string word in search.Split(' '))
    {
        query = query.Search(x => x.Brand, word, boost: 5)
                     .Search(x => x.Model, word, boost: 3)
                     .Search(x => x.Variant, word)
                     .Search(x => x.Color, word);
    }
}
 

Комментарии:

1. Ознакомьтесь с демонстрацией этого запроса demo.ravendb.net/demos/csharp/queries/…

2. Кроме того, смотрите этот код в тестах github.com/ravendb/ravendb/blob/…

3. Кроме того, смотрите эту документацию ravendb.net/docs/article-page/5.1/Csharp/indexes/querying/…

4. @Danielle Спасибо тебе!

Ответ №1:

Решено: мне пришлось использовать запрос документа и создавать подпункты для каждого цикла.

 using (var session = this.ravenSession.Store.OpenAsyncSession())
{
    var query = session.Advanced.AsyncDocumentQuery<TestDocument>();

    var words = search.Split(' ');

    for (int i = 0; i < words.Length; i  )
    {
        query.OpenSubclause();

        query = query.Search(x => x.Brand, words[i]).Boost(5).OrElse()
                     .Search(x => x.Model, words[i]).Boost(3).OrElse()
                     .Search(x => x.Variant, words[i]).OrElse()
                     .Search(x => x.Color, words[i]);

        query.CloseSubclause();

        if (i < (words.Length - 1))
        {
            query.AndAlso();
        }
    }
}