Не могли бы вы рассказать, как выполнить простой полнотекстовый поиск в RavenDb. База данных хранится в документе: Movie {Name = "Pirates of the Carribean" }. Я хочу, чтобы этот документ был найден на поисковой фразе "Пираты Карибского моря" или любой другой комбинации слов.
Полнотекстовый поиск RavenDB
Ответ 1
То, о чем вы беспокоитесь, не имеет никакого отношения к полному тексту - по умолчанию Lucene работает на основе OR, а то, что вы хотите, - это AND
Если бы я был вами, я бы сделал
String[] terms = searchTerm.Split(" "); // Or whatever the string.split method is
и
.Where("Name:(" + String.Join(" AND ", terms) + ")");
Ваш индекс должен выглядеть примерно так:
public class Movie_ByName : AbstractIndexCreationTask
{
public override IndexDefinition CreateIndexDefinition()
{
return new IndexDefinitionBuilder<Movie>
{
Map = movies => from movie in movies
select new { movie.Name, market.Id },
Indexes =
{
{x => x.Name, FieldIndexing.Analyzed}
}
}
.ToIndexDefinition(DocumentStore.Conventions);
}
Вам не нужна память, вы не запрашиваете данные из lucene напрямую в любое время. Возможно, вам даже не нужен индекс (вам может понадобиться FieldIndexing.Analyzed и может уйти от использования только динамических запросов здесь)
До вас, хотя.
Ответ 2
Борис, Ответ Rob имеет нужный индекс, но для запросов это немного неудобно. Вы можете сделать это, используя:
session.Query<Movie, Movie_ByName>()
.Search(x=>x.Name, searchTerms)
.ToList()
Это будет
Ответ 3
Вот как я получил поиск термина "ANDing".
Сначала убедитесь, что ваше поле проиндексировано и проанализировано:
public class MyIndex: AbstractIndexCreationTask<MyDocument>
{
public MyIndex()
{
Map = docs => from d in docs
select new { d.MyTextField };
Index(x => x.MyTextField, FieldIndexing.Analyzed);
}
}
Затем запрос от клиента:
var query = session.Query<MyDocument, MyIndex>();
query = theSearchText
.Split(new[] {" "}, StringSplitOptions.RemoveEmptyEntries)
.Aggregate(query, (q, term) =>
q.Search(x => x.MyTextField, term, options: SearchOptions.And));