我读了How to incorporate multiple fields in QueryParser?,但没有听懂。
目前,我有一个非常奇怪的结构,例如:
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”字段中寻找搜索词。
最佳答案
有3种方法可以做到这一点。
第一种方法是手动构造查询,这是QueryParser
在内部进行的操作。这是执行此操作最强大的方法,这意味着如果要阻止访问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
,允许访问它具有的所有功能,但是它将搜索多个字段。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
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的内容时创建一个新字段,您可以在其中放置正文和标题的内容,然后只需搜索一个字段。
关于java - 如何在Lucene QueryParser中指定两个字段?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/2005084/