Update QueryParser
This commit is contained in:
parent
8257f31d38
commit
7a33d8d1d5
@ -130,11 +130,10 @@ versions:
|
||||
# Score modifying queries
|
||||
# ============
|
||||
|
||||
# Query that fixes the score of a query
|
||||
# Query that fixes the score of a query to 1
|
||||
ConstantScoreQuery:
|
||||
data:
|
||||
query: Query
|
||||
score: float
|
||||
# Query that boosts the query score
|
||||
BoostQuery:
|
||||
data:
|
||||
|
@ -1,9 +1,33 @@
|
||||
package it.cavallium.dbengine.client.query;
|
||||
|
||||
import it.cavallium.dbengine.client.query.current.data.BooleanQueryPart;
|
||||
import it.cavallium.dbengine.client.query.current.data.BoostQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.BoxedQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.ConstantScoreQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.IntPointExactQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.IntPointRangeQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.LongPointExactQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.LongPointRangeQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.NumericSort;
|
||||
import it.cavallium.dbengine.client.query.current.data.PhraseQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.QueryParams;
|
||||
import org.apache.commons.lang.NotImplementedException;
|
||||
import it.cavallium.dbengine.client.query.current.data.SortedDocFieldExistsQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.SortedNumericDocValuesFieldSlowRangeQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.SynonymQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.TermAndBoost;
|
||||
import it.cavallium.dbengine.client.query.current.data.TermPosition;
|
||||
import it.cavallium.dbengine.client.query.current.data.TermQuery;
|
||||
import it.cavallium.dbengine.client.query.current.data.WildcardQuery;
|
||||
import org.apache.lucene.document.IntPoint;
|
||||
import org.apache.lucene.document.LongPoint;
|
||||
import org.apache.lucene.document.SortedNumericDocValuesField;
|
||||
import org.apache.lucene.index.Term;
|
||||
import org.apache.lucene.search.BooleanClause.Occur;
|
||||
import org.apache.lucene.search.BooleanQuery.Builder;
|
||||
import org.apache.lucene.search.DocValuesFieldExistsQuery;
|
||||
import org.apache.lucene.search.FuzzyQuery;
|
||||
import org.apache.lucene.search.MatchAllDocsQuery;
|
||||
import org.apache.lucene.search.MatchNoDocsQuery;
|
||||
import org.apache.lucene.search.Query;
|
||||
import org.apache.lucene.search.ScoreMode;
|
||||
import org.apache.lucene.search.Sort;
|
||||
@ -14,7 +38,107 @@ import org.apache.lucene.search.SortedNumericSortField;
|
||||
public class QueryParser {
|
||||
public static Query toQuery(it.cavallium.dbengine.client.query.current.data.Query query) {
|
||||
if (query == null) return null;
|
||||
throw new NotImplementedException();
|
||||
switch (query.getBasicType$()) {
|
||||
case BooleanQuery:
|
||||
var booleanQuery = (it.cavallium.dbengine.client.query.current.data.BooleanQuery) query;
|
||||
var bq = new Builder();
|
||||
for (BooleanQueryPart part : booleanQuery.getParts()) {
|
||||
Occur occur;
|
||||
switch (part.getOccur().getBasicType$()) {
|
||||
case OccurFilter:
|
||||
occur = Occur.FILTER;
|
||||
break;
|
||||
case OccurMust:
|
||||
occur = Occur.MUST;
|
||||
break;
|
||||
case OccurShould:
|
||||
occur = Occur.SHOULD;
|
||||
break;
|
||||
case OccurMustNot:
|
||||
occur = Occur.MUST_NOT;
|
||||
break;
|
||||
default:
|
||||
throw new IllegalStateException("Unexpected value: " + part.getOccur().getBasicType$());
|
||||
}
|
||||
bq.add(toQuery(part.getQuery()), occur);
|
||||
}
|
||||
bq.setMinimumNumberShouldMatch(booleanQuery.getMinShouldMatch());
|
||||
return bq.build();
|
||||
case IntPointExactQuery:
|
||||
var intPointExactQuery = (IntPointExactQuery) query;
|
||||
return IntPoint.newExactQuery(intPointExactQuery.getField(), intPointExactQuery.getValue());
|
||||
case LongPointExactQuery:
|
||||
var longPointExactQuery = (LongPointExactQuery) query;
|
||||
return LongPoint.newExactQuery(longPointExactQuery.getField(), longPointExactQuery.getValue());
|
||||
case TermQuery:
|
||||
var termQuery = (TermQuery) query;
|
||||
return new org.apache.lucene.search.TermQuery(toTerm(termQuery.getTerm()));
|
||||
case BoostQuery:
|
||||
var boostQuery = (BoostQuery) query;
|
||||
return new org.apache.lucene.search.BoostQuery(toQuery(boostQuery.getQuery()), boostQuery.getScoreBoost());
|
||||
case ConstantScoreQuery:
|
||||
var constantScoreQuery = (ConstantScoreQuery) query;
|
||||
return new org.apache.lucene.search.ConstantScoreQuery(toQuery(constantScoreQuery.getQuery()));
|
||||
case BoxedQuery:
|
||||
return toQuery(((BoxedQuery) query).getQuery());
|
||||
case FuzzyQuery:
|
||||
var fuzzyQuery = (it.cavallium.dbengine.client.query.current.data.FuzzyQuery) query;
|
||||
return new FuzzyQuery(toTerm(fuzzyQuery.getTerm()),
|
||||
fuzzyQuery.getMaxEdits(),
|
||||
fuzzyQuery.getPrefixLength(),
|
||||
fuzzyQuery.getMaxExpansions(),
|
||||
fuzzyQuery.getTranspositions()
|
||||
);
|
||||
case IntPointRangeQuery:
|
||||
var intPointRangeQuery = (IntPointRangeQuery) query;
|
||||
return IntPoint.newRangeQuery(intPointRangeQuery.getField(),
|
||||
intPointRangeQuery.getMin(),
|
||||
intPointRangeQuery.getMax()
|
||||
);
|
||||
case LongPointRangeQuery:
|
||||
var longPointRangeQuery = (LongPointRangeQuery) query;
|
||||
return LongPoint.newRangeQuery(longPointRangeQuery.getField(),
|
||||
longPointRangeQuery.getMin(),
|
||||
longPointRangeQuery.getMax()
|
||||
);
|
||||
case MatchAllDocsQuery:
|
||||
return new MatchAllDocsQuery();
|
||||
case MatchNoDocsQuery:
|
||||
return new MatchNoDocsQuery();
|
||||
case PhraseQuery:
|
||||
var phraseQuery = (PhraseQuery) query;
|
||||
var pqb = new org.apache.lucene.search.PhraseQuery.Builder();
|
||||
for (TermPosition phrase : phraseQuery.getPhrase()) {
|
||||
pqb.add(toTerm(phrase.getTerm()), phrase.getPosition());
|
||||
}
|
||||
pqb.setSlop(phraseQuery.getSlop());
|
||||
return pqb.build();
|
||||
case SortedDocFieldExistsQuery:
|
||||
var sortedDocFieldExistsQuery = (SortedDocFieldExistsQuery) query;
|
||||
return new DocValuesFieldExistsQuery(sortedDocFieldExistsQuery.getField());
|
||||
case SynonymQuery:
|
||||
var synonymQuery = (SynonymQuery) query;
|
||||
var sqb = new org.apache.lucene.search.SynonymQuery.Builder(synonymQuery.getField());
|
||||
for (TermAndBoost part : synonymQuery.getParts()) {
|
||||
sqb.addTerm(toTerm(part.getTerm()), part.getBoost());
|
||||
}
|
||||
return sqb.build();
|
||||
case SortedNumericDocValuesFieldSlowRangeQuery:
|
||||
var sortedNumericDocValuesFieldSlowRangeQuery = (SortedNumericDocValuesFieldSlowRangeQuery) query;
|
||||
return SortedNumericDocValuesField.newSlowRangeQuery(sortedNumericDocValuesFieldSlowRangeQuery.getField(),
|
||||
sortedNumericDocValuesFieldSlowRangeQuery.getMin(),
|
||||
sortedNumericDocValuesFieldSlowRangeQuery.getMax()
|
||||
);
|
||||
case WildcardQuery:
|
||||
var wildcardQuery = (WildcardQuery) query;
|
||||
return new org.apache.lucene.search.WildcardQuery(new Term(wildcardQuery.getField(), wildcardQuery.getPattern()));
|
||||
default:
|
||||
throw new IllegalStateException("Unexpected value: " + query.getBasicType$());
|
||||
}
|
||||
}
|
||||
|
||||
private static Term toTerm(it.cavallium.dbengine.client.query.current.data.Term term) {
|
||||
return new Term(term.getField(), term.getValue());
|
||||
}
|
||||
|
||||
public static boolean isScoringEnabled(QueryParams queryParams) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user