У меня есть набор объектов типа Idea
public class Idea
{
public string Title { get; set; }
public string Body { get; set; }
}
Я хочу искать объекты по подстроке. Например, когда у меня есть объект "идея", я хочу, чтобы он был найден, когда я ввожу какую-либо подстроку "идеи": i, id, ide, idea, d, de, dea, e, ea, a.
Я использую RavenDB для хранения данных. Поисковый запрос выглядит так:
var ideas = session
.Query<IdeaByBodyOrTitle.IdeaSearchResult, IdeaByBodyOrTitle>()
.Where(x => x.Query.Contains(query))
.As<Idea>()
.ToList();
а индекс следующий:
public class IdeaByBodyOrTitle : AbstractIndexCreationTask<Idea, IdeaByBodyOrTitle.IdeaSearchResult>
{
public class IdeaSearchResult
{
public string Query;
public Idea Idea;
}
public IdeaByBodyOrTitle()
{
Map = ideas => from idea in ideas
select new
{
Query = new object[] { idea.Title.SplitSubstrings().Concat(idea.Body.SplitSubstrings()).Distinct().ToArray() },
idea
};
Indexes.Add(x => x.Query, FieldIndexing.Analyzed);
}
}
SplitSubstrings()
- это метод расширения, который возвращает все различные подстроки заданной строки:
static class StringExtensions
{
public static string[] SplitSubstrings(this string s)
{
s = s ?? string.Empty;
List<string> substrings = new List<string>();
for (int i = 0; i < s.Length; i++)
{
for (int j = 1; j <= s.Length - i; j++)
{
substrings.Add(s.Substring(i, j));
}
}
return substrings.Select(x => x.Trim()).Where(x => !string.IsNullOrEmpty(x)).Distinct().ToArray();
}
}
Это не работает. В частности, поскольку RavenDB не распознает метод SplitSubstrings()
, потому что он находится в моей пользовательской сборке. Как сделать эту работу, в основном, как заставить RavenDB распознать этот метод? Кроме того, подходит ли мой подход для такого поиска (поиск подстрокой)?
ИЗМЕНИТЬ
В принципе, я хочу построить функцию автозаполнения в этом поиске, поэтому она должна быть быстрой.
Btw: Я использую RavenDB - Build # 960