QueryParser中指定两个字段

QueryParser中指定两个字段

本文介绍了如何在Lucene QueryParser中指定两个字段?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我阅读了如何在QueryParser中合并多个字段?但我不明白.

目前,我有一个非常奇怪的结构,例如:

At the moment i have a very strange construction like:

parser = New QueryParser("bodytext", analyzer)
parser2 = New QueryParser("title", analyzer)
query = parser.Parse(strSuchbegriff)
query2 = parser.Parse(strSuchbegriff)

我该怎么办?

parser = New QuerParser ("bodytext" , "title",analyzer)
query =parser.Parse(strSuchbegriff)

因此解析器在"bodytext"字段和"title"字段中寻找搜索词.

so the Parser looks for the searching word in the field "bodytext" an in the field "title".

推荐答案

共有3种方法.

第一种方法是手动构造查询,这是QueryParser在内部执行的操作.这是执行此操作最强大的方法,并且意味着如果要阻止访问QueryParser的某些更奇特的功能,则不必解析用户输入:

The first way is to construct a query manually, this is what QueryParser is doing internally. This is the most powerful way to do it, and means that you don't have to parse the user input if you want to prevent access to some of the more exotic features of QueryParser:

IndexReader reader = IndexReader.Open("<lucene dir>");
Searcher searcher = new IndexSearcher(reader);

BooleanQuery booleanQuery = new BooleanQuery();
Query query1 = new TermQuery(new Term("bodytext", "<text>"));
Query query2 = new TermQuery(new Term("title", "<text>"));
booleanQuery.add(query1, BooleanClause.Occur.SHOULD);
booleanQuery.add(query2, BooleanClause.Occur.SHOULD);
// Use BooleanClause.Occur.MUST instead of BooleanClause.Occur.SHOULD
// for AND queries
Hits hits = searcher.Search(booleanQuery);

第二种方法是使用MultiFieldQueryParser,其行为类似于QueryParser,除了可以搜索多个字段之外,还可以访问其具有的所有功能.

The second way is to use MultiFieldQueryParser, this behaves like QueryParser, allowing access to all the power that it has, except that it will search over multiple fields.

IndexReader reader = IndexReader.Open("<lucene dir>");
Searcher searcher = new IndexSearcher(reader);

Analyzer analyzer = new StandardAnalyzer();
MultiFieldQueryParser queryParser = new MultiFieldQueryParser(
                                        new string[] {"bodytext", "title"},
                                        analyzer);

Hits hits = searcher.Search(queryParser.parse("<text>"));

最后一种方法是使用QueryParser的特殊语法请参阅这里.

The final way is to use the special syntax of QueryParser see here.

IndexReader reader = IndexReader.Open("<lucene dir>");
Searcher searcher = new IndexSearcher(reader);

Analyzer analyzer = new StandardAnalyzer();
QueryParser queryParser = new QueryParser("<default field>", analyzer);
// <default field> is the field that QueryParser will search if you don't
// prefix it with a field.
string special = "bodytext:" + text + " OR title:" + text;

Hits hits = searcher.Search(queryParser.parse(special));

您的另一种选择是在索引名为bodytextandtitle的内容时创建一个新字段,您可以在其中放置 正文和标题的内容,然后只需要搜索一个字段即可.

Your other option is to create new field when you index your content called bodytextandtitle, into which you can place the contents of both bodytext and title, then you only have to search one field.

这篇关于如何在Lucene QueryParser中指定两个字段?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

08-18 19:19