#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();
}
}
}