Полнотекстовый поиск RavenDB

Не могли бы вы рассказать, как выполнить простой полнотекстовый поиск в RavenDb. База данных хранится в документе: Movie {Name = "Pirates of the Carribean" }. Я хочу, чтобы этот документ был найден на поисковой фразе "Пираты Карибского моря" или любой другой комбинации слов.

Ответ 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));