Lucene .net 搜索具有不同序列的文本
Lucene .net Search Text With Different Sequence
我是 lucene.net 的新手。我正在开发一个 API 来扫描名单。参数将输入此人的全名。
然而,使用当前代码,如果我输入 'Pit Bull' 搜索名单,它将出现 'Pit Bull Adam'、'Pit Tim Bull' 等...
但我想要的结果只是 'Pit Bull' 或 'Bull Pit'。
我使用的分析器或查询是否正确?我该怎么办?
这是我创建的索引。
var doc = new Document();
doc.Add(new Field("Id", model.EntityId.ToString(), Field.Store.YES, Field.Index.NOT_ANALYZED));
doc.Add(new Field("FullName", model.FullName, Field.Store.YES, Field.Index.ANALYZED));
doc.Add(new Field("Name2", model.Name2?? "", Field.Store.YES, Field.Index.ANALYZED));
doc.Add(new Field("Name3", model.Name3?? "", Field.Store.YES, Field.Index.ANALYZED));
doc.Add(new Field("Gender", indexModel.GenderType.HasValue ? indexModel.GenderType.Value.ToString() : "", Field.Store.YES,
Field.Index.NOT_ANALYZED, Field.TermVector.NO));
这是我的搜索方法。
using (var indexReader = IndexReader.Open(ramDirectory, true))
{
using (var searcher = new IndexSearcher(indexReader))
{
var analyzer = new StandardAnalyzer(Lucene.Net.Util.Version.LUCENE_30);
MultiFieldQueryParser _MultiMatchName = new
MultiFieldQueryParser(Lucene.Net.Util.Version.LUCENE_30,
new string[] { "FullName", "Name2", "Name3" }, analyzer);
const int hitLimits = 1000;
_MultiMatchName.DefaultOperator = QueryParser.Operator.AND;
var query = new BooleanQuery();
query.Add(inputName,Occur.MUST);
}
}
原来我应该使用 WhitespaceAnalyzer。创建索引和搜索索引时。
using (var indexReader = IndexReader.Open(ramDirectory, true))
{
using (var searcher = new IndexSearcher(indexReader))
{
var analyzer = new WhitespaceAnalyzer();
MultiFieldQueryParser _MultiMatchName = new
MultiFieldQueryParser(Lucene.Net.Util.Version.LUCENE_30,
new string[] { "FullName", "Name2", "Name3" }, analyzer);
const int hitLimits = 1000;
_MultiMatchName.DefaultOperator = QueryParser.Operator.AND;
var query = new BooleanQuery();
query.Add(inputName,Occur.MUST);
}
}
我是 lucene.net 的新手。我正在开发一个 API 来扫描名单。参数将输入此人的全名。
然而,使用当前代码,如果我输入 'Pit Bull' 搜索名单,它将出现 'Pit Bull Adam'、'Pit Tim Bull' 等...
但我想要的结果只是 'Pit Bull' 或 'Bull Pit'。
我使用的分析器或查询是否正确?我该怎么办?
这是我创建的索引。
var doc = new Document();
doc.Add(new Field("Id", model.EntityId.ToString(), Field.Store.YES, Field.Index.NOT_ANALYZED));
doc.Add(new Field("FullName", model.FullName, Field.Store.YES, Field.Index.ANALYZED));
doc.Add(new Field("Name2", model.Name2?? "", Field.Store.YES, Field.Index.ANALYZED));
doc.Add(new Field("Name3", model.Name3?? "", Field.Store.YES, Field.Index.ANALYZED));
doc.Add(new Field("Gender", indexModel.GenderType.HasValue ? indexModel.GenderType.Value.ToString() : "", Field.Store.YES,
Field.Index.NOT_ANALYZED, Field.TermVector.NO));
这是我的搜索方法。
using (var indexReader = IndexReader.Open(ramDirectory, true))
{
using (var searcher = new IndexSearcher(indexReader))
{
var analyzer = new StandardAnalyzer(Lucene.Net.Util.Version.LUCENE_30);
MultiFieldQueryParser _MultiMatchName = new
MultiFieldQueryParser(Lucene.Net.Util.Version.LUCENE_30,
new string[] { "FullName", "Name2", "Name3" }, analyzer);
const int hitLimits = 1000;
_MultiMatchName.DefaultOperator = QueryParser.Operator.AND;
var query = new BooleanQuery();
query.Add(inputName,Occur.MUST);
}
}
原来我应该使用 WhitespaceAnalyzer。创建索引和搜索索引时。
using (var indexReader = IndexReader.Open(ramDirectory, true))
{
using (var searcher = new IndexSearcher(indexReader))
{
var analyzer = new WhitespaceAnalyzer();
MultiFieldQueryParser _MultiMatchName = new
MultiFieldQueryParser(Lucene.Net.Util.Version.LUCENE_30,
new string[] { "FullName", "Name2", "Name3" }, analyzer);
const int hitLimits = 1000;
_MultiMatchName.DefaultOperator = QueryParser.Operator.AND;
var query = new BooleanQuery();
query.Add(inputName,Occur.MUST);
}
}