LuceneのStandardAnalyzerでbooleanQueryを使用する方法検索?Lucene BooleanQuery
3
A
答えて
6
あなたは、QueryParserオブジェクトを使用してブール型クエリを解析することを指摘していますか? Lucene query syntax documentationには、必要なものすべてが必要です。
0
BooleanQuery. BooleanQuery
は、オプション、必須または禁止のサブクエリであるブール句のコンテナです。
公共ボイド追加(クエリ、クエリ、必要なブール、禁止ブール)
2
文書によると、ブールクエリを一度に作成する必要があります:あなたは、通常のように見えるAPIメソッドを使用することBooleanQuery
に句を追加することができますBooleanQuery.QueryBuilderによって作成され、次に不変であるとみなされます。それは作品
public Query parse(Type type, String fieldName, Object value) throws IOException {
final String field;
MappedFieldType fieldType = context.fieldMapper(fieldName);
if (fieldType != null) {
field = fieldType.name();
} else {
field = fieldName;
}
/*
* If the user forced an analyzer we really don't care if they are
* searching a type that wants term queries to be used with query string
* because the QueryBuilder will take care of it. If they haven't forced
* an analyzer then types like NumberFieldType that want terms with
* query string will blow up because their analyzer isn't capable of
* passing through QueryBuilder.
*/
boolean noForcedAnalyzer = this.analyzer == null;
if (fieldType != null && fieldType.tokenized() == false && noForcedAnalyzer) {
return blendTermQuery(new Term(fieldName, value.toString()), fieldType);
}
Analyzer analyzer = getAnalyzer(fieldType);
assert analyzer != null;
MatchQueryBuilder builder = new MatchQueryBuilder(analyzer, fieldType);
builder.setEnablePositionIncrements(this.enablePositionIncrements);
Query query = null;
switch(type) {
case BOOLEAN:
if (commonTermsCutoff == null) {
query = builder.createBooleanQuery(field, value.toString(), occur);
} else {
query = builder.createCommonTermsQuery(field, value.toString(), occur, occur, commonTermsCutoff, fieldType);
}
break;
case PHRASE:
query = builder.createPhraseQuery(field, value.toString(), phraseSlop);
break;
case PHRASE_PREFIX:
query = builder.createPhrasePrefixQuery(field, value.toString(), phraseSlop, maxExpansions);
break;
default:
throw new IllegalStateException("No type found for [" + type + "]");
}
if (query == null) {
return zeroTermsQuery();
} else {
return query;
}
}
関連する問題
- 1. Lucene 5.3.xでBooleanQuery Builderを使用するにはどうすればよいですか?
- 2. Luceneのクエリ得点
- 3. BooleanQueryを使用するか、さらにインデックスを書き込むか?
- 4. Lucene.Net:MultiFiledQueryParserをBooleanQueryに変換するにはどうすればよいですか?
- 5. のLucene/Hibernateは:@FullTextFilterDef FilterFactory
- 6. Lucene。
- 7. WhenepaceでLucene QueryStringを分割する最も効果的な方法
- 8. Luceneの異常な動作
- 9. luceneのURLに基づいてレコードを取得する方法
- 10. Luceneクエリの任期文書のLuceneと
- 11. lucene/python
- 12. Luceneチェックインデックスサイズ
- 13. Luceneフルテキストクエリスペルチェック
- 14. luceneの
- 15. Lucene Jackrabbit
- 16. Lucene TermFrequenciesVector
- 17. Luceneユニットテスト
- 18. Lucene KeywordAnalyzer
- 19. luceneの
- 20. なぜLucene QueryParserにアナライザが必要ですか
- 21. Lucene:検索語としての複数単語のフレーズ
- 22. Luceneのバージョン
- 23. zend検索lucene
- 24. コマンドラインlucene app
- 25. LuceneのHive
- 26. Lucene 3.1ペイロード
- 27. Luceneのマージインデックス
- 28. Lucene Term lookup
- 29. LuceneのAnalyzerUtilエラー
- 30. クエリ拡張lucene
:あるBooleanQuery.Builder.add(org.apache.lucene.search.BooleanClause)
コード例はhttp://programtalk.com/java-api-usage-examples/org.apache.lucene.util.QueryBuilder/ と一例与えられたことで見つけることができます参照してください。ありがとうございました – Shashi