mirror of https://github.com/apache/lucene.git
LUCENE-7376: Add support for ToParentBlockJoinQuery to fast vector highlighter's FieldQuery.
This commit is contained in:
parent
625979113f
commit
4edba94631
|
@ -84,6 +84,9 @@ Improvements
|
|||
chain that is about normalization for range/fuzzy/wildcard queries.
|
||||
(Adrien Grand)
|
||||
|
||||
* LUCENE-7376: Add support for ToParentBlockJoinQuery to fast vector highlighter's
|
||||
FieldQuery. (Martijn van Groningen)
|
||||
|
||||
Optimizations
|
||||
|
||||
* LUCENE-7330, LUCENE-7339: Speed up conjunction queries. (Adrien Grand)
|
||||
|
|
|
@ -37,6 +37,7 @@ import org.apache.lucene.search.MultiTermQuery;
|
|||
import org.apache.lucene.search.PhraseQuery;
|
||||
import org.apache.lucene.search.Query;
|
||||
import org.apache.lucene.search.TermQuery;
|
||||
import org.apache.lucene.search.join.ToParentBlockJoinQuery;
|
||||
import org.apache.lucene.search.vectorhighlight.FieldTermStack.TermInfo;
|
||||
|
||||
/**
|
||||
|
@ -137,6 +138,11 @@ public class FieldQuery {
|
|||
if (q != null) {
|
||||
flatten( q, reader, flatQueries, boost);
|
||||
}
|
||||
} else if (sourceQuery instanceof ToParentBlockJoinQuery) {
|
||||
Query childQuery = ((ToParentBlockJoinQuery) sourceQuery).getChildQuery();
|
||||
if (childQuery != null) {
|
||||
flatten(childQuery, reader, flatQueries, boost);
|
||||
}
|
||||
} else if (reader != null) {
|
||||
Query query = sourceQuery;
|
||||
Query rewritten;
|
||||
|
|
|
@ -27,12 +27,16 @@ import org.apache.lucene.search.BooleanClause.Occur;
|
|||
import org.apache.lucene.search.BooleanQuery;
|
||||
import org.apache.lucene.search.BoostQuery;
|
||||
import org.apache.lucene.search.ConstantScoreQuery;
|
||||
import org.apache.lucene.search.MatchAllDocsQuery;
|
||||
import org.apache.lucene.search.PrefixQuery;
|
||||
import org.apache.lucene.search.Query;
|
||||
import org.apache.lucene.search.RegexpQuery;
|
||||
import org.apache.lucene.search.TermQuery;
|
||||
import org.apache.lucene.search.TermRangeQuery;
|
||||
import org.apache.lucene.search.WildcardQuery;
|
||||
import org.apache.lucene.search.join.QueryBitSetProducer;
|
||||
import org.apache.lucene.search.join.ScoreMode;
|
||||
import org.apache.lucene.search.join.ToParentBlockJoinQuery;
|
||||
import org.apache.lucene.search.vectorhighlight.FieldQuery.QueryPhraseMap;
|
||||
import org.apache.lucene.search.vectorhighlight.FieldTermStack.TermInfo;
|
||||
import org.apache.lucene.util.BytesRef;
|
||||
|
@ -951,4 +955,15 @@ public class FieldQueryTest extends AbstractTestCase {
|
|||
assertCollectionQueries( flatQueries, tq( boost, "A" ) );
|
||||
}
|
||||
|
||||
public void testFlattenToParentBlockJoinQuery() throws Exception {
|
||||
initBoost();
|
||||
Query childQuery = tq(boost, "a");
|
||||
Query query = new ToParentBlockJoinQuery(childQuery, new QueryBitSetProducer(new MatchAllDocsQuery()), ScoreMode.None);
|
||||
query = new BoostQuery(query, boost );
|
||||
FieldQuery fq = new FieldQuery(query, true, true );
|
||||
Set<Query> flatQueries = new HashSet<>();
|
||||
fq.flatten(query, reader, flatQueries, 1f );
|
||||
assertCollectionQueries(flatQueries, tq(boost, "a"));
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue