mirror of https://github.com/apache/lucene.git
LUCENE-7874: DisjunctionMaxQuery rewrites to a BooleanQuery when tiebreaker is set to 1.
This commit is contained in:
parent
0c683305a4
commit
68d29c9b4f
|
@ -112,6 +112,8 @@ Optimizations
|
||||||
query is a point (for 2D) or a is a simple date interval (e.g. 1 month). When
|
query is a point (for 2D) or a is a simple date interval (e.g. 1 month). When
|
||||||
the strategy is marked as pointsOnly, the results is a TermQuery. (David Smiley)
|
the strategy is marked as pointsOnly, the results is a TermQuery. (David Smiley)
|
||||||
|
|
||||||
|
* LUCENE-7874: DisjunctionMaxQuery rewrites to a BooleanQuery when tiebreaker is set to 1. (Jim Ferenczi)
|
||||||
|
|
||||||
Other
|
Other
|
||||||
|
|
||||||
* LUCENE-7328: Remove LegacyNumericEncoding from GeoPointField. (Nick Knize)
|
* LUCENE-7328: Remove LegacyNumericEncoding from GeoPointField. (Nick Knize)
|
||||||
|
|
|
@ -178,6 +178,14 @@ public final class DisjunctionMaxQuery extends Query implements Iterable<Query>
|
||||||
return disjuncts[0];
|
return disjuncts[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (tieBreakerMultiplier == 1.0f) {
|
||||||
|
BooleanQuery.Builder builder = new BooleanQuery.Builder();
|
||||||
|
for (Query sub : disjuncts) {
|
||||||
|
builder.add(sub, BooleanClause.Occur.SHOULD);
|
||||||
|
}
|
||||||
|
return builder.build();
|
||||||
|
}
|
||||||
|
|
||||||
boolean actuallyRewritten = false;
|
boolean actuallyRewritten = false;
|
||||||
List<Query> rewrittenDisjuncts = new ArrayList<>();
|
List<Query> rewrittenDisjuncts = new ArrayList<>();
|
||||||
for (Query sub : disjuncts) {
|
for (Query sub : disjuncts) {
|
||||||
|
|
|
@ -524,6 +524,21 @@ public class TestDisjunctionMaxQuery extends LuceneTestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testRewriteBoolean() throws Exception {
|
||||||
|
Query sub1 = tq("hed", "albino");
|
||||||
|
Query sub2 = tq("hed", "elephant");
|
||||||
|
DisjunctionMaxQuery q = new DisjunctionMaxQuery(
|
||||||
|
Arrays.asList(
|
||||||
|
sub1, sub2
|
||||||
|
), 1.0f);
|
||||||
|
Query rewritten = s.rewrite(q);
|
||||||
|
assertTrue(rewritten instanceof BooleanQuery);
|
||||||
|
BooleanQuery bq = (BooleanQuery) rewritten;
|
||||||
|
assertEquals(bq.clauses().size(), 2);
|
||||||
|
assertEquals(bq.clauses().get(0), new BooleanClause(sub1, BooleanClause.Occur.SHOULD));
|
||||||
|
assertEquals(bq.clauses().get(1), new BooleanClause(sub2, BooleanClause.Occur.SHOULD));
|
||||||
|
}
|
||||||
|
|
||||||
/** macro */
|
/** macro */
|
||||||
protected Query tq(String f, String t) {
|
protected Query tq(String f, String t) {
|
||||||
return new TermQuery(new Term(f, t));
|
return new TermQuery(new Term(f, t));
|
||||||
|
|
Loading…
Reference in New Issue