利用Boost影响Lucene查询结果的排序
2008-01-03 22:57
387 查看
以下代码在Lucene2.1下通过,主要是通过设置Document的Boost来影响文档的权重,以达到控制查询结果顺序的目的(前提是不利用Sort排序的情况下):
private void btnSearch_Click(object sender, EventArgs e)
{
RAMDirectory ramDir = new RAMDirectory();
IndexWriter iw = new IndexWriter(ramDir,new StandardAnalyzer(),true);
string[] NameList =
{ "you are my friend", "you are my wife", "I love you" };
string[] FileList =
{ "1", "2", "3" };
for (int i = 0; i < NameList.Length; i++)
{
Document doc = new Document();
doc.Add(new Field("name", NameList[i], Field.Store.YES, Field.Index.TOKENIZED));
doc.Add(new Field("file", FileList[i], Field.Store.YES, Field.Index.TOKENIZED));
if (i == 2)
{ doc.SetBoost(2.0f); }//这里设置了第三个文档优先级最高,所以在搜索出来的结果中,该文档排在最前
iw.AddDocument(doc);
}
iw.Close();
IndexSearcher _searcher = new IndexSearcher(ramDir);
QueryParser _parser = new QueryParser("name",new StandardAnalyzer());
Query _query = _parser.Parse("you");
Hits hitDoc = _searcher.Search(_query);
lstResult.Items.Clear();//lstResult为一个ListBox
for (int i = 0; i < hitDoc.Length(); i++)
{
Document doc = hitDoc.Doc(i);
lstResult.Items.Add(doc.Get("file") + " " + doc.Get("name"));
}
_searcher.Close();
}
以下是运行结果
private void btnSearch_Click(object sender, EventArgs e)
{
RAMDirectory ramDir = new RAMDirectory();
IndexWriter iw = new IndexWriter(ramDir,new StandardAnalyzer(),true);
string[] NameList =
{ "you are my friend", "you are my wife", "I love you" };
string[] FileList =
{ "1", "2", "3" };
for (int i = 0; i < NameList.Length; i++)
{
Document doc = new Document();
doc.Add(new Field("name", NameList[i], Field.Store.YES, Field.Index.TOKENIZED));
doc.Add(new Field("file", FileList[i], Field.Store.YES, Field.Index.TOKENIZED));
if (i == 2)
{ doc.SetBoost(2.0f); }//这里设置了第三个文档优先级最高,所以在搜索出来的结果中,该文档排在最前
iw.AddDocument(doc);
}
iw.Close();
IndexSearcher _searcher = new IndexSearcher(ramDir);
QueryParser _parser = new QueryParser("name",new StandardAnalyzer());
Query _query = _parser.Parse("you");
Hits hitDoc = _searcher.Search(_query);
lstResult.Items.Clear();//lstResult为一个ListBox
for (int i = 0; i < hitDoc.Length(); i++)
{
Document doc = hitDoc.Doc(i);
lstResult.Items.Add(doc.Get("file") + " " + doc.Get("name"));
}
_searcher.Close();
}
以下是运行结果
相关文章推荐
- 利用Boost影响Lucene查询结果的排序
- 【转】利用Boost影响Lucene查询结果的排序
- 利用Boost影响Lucene查询结果的排序
- lucene利用sort对查询结果进行排序示例
- Lucene检索结果的排序问题、boost(激励因子)
- lucene查询排序结果原理总结
- MySQL索引不仅影响查询速度而且影响查询结果的排序
- LuceneSearch 现在要对查询结果进行排序的显示。
- 利用冗余字段解决查询结果排序慢的问题
- lucene学习记录(3) - 结果排序, 范围查询
- JAVA_WEB项目之Lucene实现检索结果排序和关键字在索引库中多字段查询结果进行高亮显示
- 利用redis缓存mysql查询结果,关于缓存命名
- 索引影响查询结果顺序的示例
- SQL技巧(2) 查询结果排序
- mysql在查询结果中增加排序字段
- Hibernate查询结果排序
- Lucene查询结果Hits的二次封装
- 如何使用lucene.net,建立索引,索引目录,查询返回结果
- sqlserver 按照特定值排序查询结果
- SQL Cookbook:二、查询结果排序(4)对字母数字混合的数据排序