让我解释一下我的问题。我正在使用Lucene在asp.net网页中搜索并显示结果。当我搜索时,Lucene显示与我的搜索相关的所有记录。例如,我有5000条名为John的记录。如果我键入John,它将显示所有这5000条记录。我想根据其他一些属性限制这5000条记录。我有四个属性,即名字,姓氏,DOB和ID。在那5000条记录中,我希望它只显示用户输入的DOB。这意味着只显示拥有DOB为5/12/1998的约翰的记录。这会将结果限制为大约50条记录。完成后,我想搜索具有相同ID的所有字段,然后显示这些记录。最后,我将使用给定的DOB和相同的ID记录John的记录。
注意:DOB过滤是出于安全目的。
以下是我的搜索代码。
List<SearchResults> Searchresults = new List<SearchResults>();
string indexFileLocation = @"C:\o";
Lucene.Net.Store.Directory dir = Lucene.Net.Store.FSDirectory.GetDirectory(indexFileLocation);
string[] searchfields = new string[] { "fname", "lname", "dob", "id"};
IndexSearcher indexSearcher = new IndexSearcher(dir);
var hits = indexSearcher.Search(QueryMaker(searchString, searchfields));
for (int i = 0; i < hits.Length(); i++)
{
SearchResults result = new SearchResults();
result.fname = hits.Doc(i).GetField("fname").StringValue();
result.lname = hits.Doc(i).GetField("lname").StringValue();
result.dob = hits.Doc(i).GetField("dob").StringValue();
result.id = hits.Doc(i).GetField("id").StringValue();
Searchresults.Add(result);
}
如果您有任何疑问,请与我们联系。
答案 0 :(得分:3)
我讨厌这样做。但我找到了答案。
它的
Filter fil= new QueryWrapperFilter(new TermQuery( new Term(field, "5/12/1998")));
var hits = indexSearcher.Search(QueryMaker(searchString, searchfields), fil);
您可以使用上面的代码过滤结果。
我不认为在过滤查找值后可以返回。有人不同意吗?