mirror of https://github.com/apache/lucene.git
SOLR-9993: Add support for ExpandComponent with PointFields
This commit is contained in:
parent
deddc9b5c8
commit
9b7c8d5606
|
@ -128,6 +128,8 @@ New Features
|
||||||
|
|
||||||
* SOLR-10349: Add totalTermFreq support to TermsComponent. (Shai Erera)
|
* SOLR-10349: Add totalTermFreq support to TermsComponent. (Shai Erera)
|
||||||
|
|
||||||
|
* SOLR-9993: Add support for ExpandComponent with PointFields. (Cao Manh Dat)
|
||||||
|
|
||||||
Optimizations
|
Optimizations
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -73,7 +73,12 @@ import org.apache.solr.common.util.SimpleOrderedMap;
|
||||||
import org.apache.solr.core.PluginInfo;
|
import org.apache.solr.core.PluginInfo;
|
||||||
import org.apache.solr.core.SolrCore;
|
import org.apache.solr.core.SolrCore;
|
||||||
import org.apache.solr.request.SolrQueryRequest;
|
import org.apache.solr.request.SolrQueryRequest;
|
||||||
|
import org.apache.solr.schema.DoublePointField;
|
||||||
import org.apache.solr.schema.FieldType;
|
import org.apache.solr.schema.FieldType;
|
||||||
|
import org.apache.solr.schema.FloatPointField;
|
||||||
|
import org.apache.solr.schema.IntPointField;
|
||||||
|
import org.apache.solr.schema.LongPointField;
|
||||||
|
import org.apache.solr.schema.SchemaField;
|
||||||
import org.apache.solr.schema.StrField;
|
import org.apache.solr.schema.StrField;
|
||||||
import org.apache.solr.schema.TrieDoubleField;
|
import org.apache.solr.schema.TrieDoubleField;
|
||||||
import org.apache.solr.schema.TrieFloatField;
|
import org.apache.solr.schema.TrieFloatField;
|
||||||
|
@ -209,7 +214,8 @@ public class ExpandComponent extends SearchComponent implements PluginInfoInitia
|
||||||
SolrIndexSearcher searcher = req.getSearcher();
|
SolrIndexSearcher searcher = req.getSearcher();
|
||||||
LeafReader reader = searcher.getSlowAtomicReader();
|
LeafReader reader = searcher.getSlowAtomicReader();
|
||||||
|
|
||||||
FieldType fieldType = searcher.getSchema().getField(field).getType();
|
SchemaField schemaField = searcher.getSchema().getField(field);
|
||||||
|
FieldType fieldType = schemaField.getType();
|
||||||
|
|
||||||
SortedDocValues values = null;
|
SortedDocValues values = null;
|
||||||
long nullValue = 0;
|
long nullValue = 0;
|
||||||
|
@ -228,17 +234,18 @@ public class ExpandComponent extends SearchComponent implements PluginInfoInitia
|
||||||
//Get the nullValue for the numeric collapse field
|
//Get the nullValue for the numeric collapse field
|
||||||
String defaultValue = searcher.getSchema().getField(field).getDefaultValue();
|
String defaultValue = searcher.getSchema().getField(field).getDefaultValue();
|
||||||
if(defaultValue != null) {
|
if(defaultValue != null) {
|
||||||
if(fieldType instanceof TrieIntField || fieldType instanceof TrieLongField) {
|
if(fieldType instanceof TrieIntField || fieldType instanceof TrieLongField ||
|
||||||
|
fieldType instanceof IntPointField || fieldType instanceof LongPointField) {
|
||||||
nullValue = Long.parseLong(defaultValue);
|
nullValue = Long.parseLong(defaultValue);
|
||||||
} else if(fieldType instanceof TrieFloatField){
|
} else if(fieldType instanceof TrieFloatField || fieldType instanceof FloatPointField){
|
||||||
nullValue = Float.floatToIntBits(Float.parseFloat(defaultValue));
|
nullValue = Float.floatToIntBits(Float.parseFloat(defaultValue));
|
||||||
} else if(fieldType instanceof TrieDoubleField){
|
} else if(fieldType instanceof TrieDoubleField || fieldType instanceof DoublePointField){
|
||||||
nullValue = Double.doubleToLongBits(Double.parseDouble(defaultValue));
|
nullValue = Double.doubleToLongBits(Double.parseDouble(defaultValue));
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if(fieldType instanceof TrieFloatField){
|
if(fieldType instanceof TrieFloatField || fieldType instanceof FloatPointField){
|
||||||
nullValue = Float.floatToIntBits(0.0f);
|
nullValue = Float.floatToIntBits(0.0f);
|
||||||
} else if(fieldType instanceof TrieDoubleField){
|
} else if(fieldType instanceof TrieDoubleField || fieldType instanceof DoublePointField){
|
||||||
nullValue = Double.doubleToLongBits(0.0f);
|
nullValue = Double.doubleToLongBits(0.0f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -369,7 +376,11 @@ public class ExpandComponent extends SearchComponent implements PluginInfoInitia
|
||||||
}
|
}
|
||||||
|
|
||||||
if(count > 0 && count < 200) {
|
if(count > 0 && count < 200) {
|
||||||
groupQuery = getGroupQuery(field, fieldType, count, groupSet);
|
if (fieldType.isPointField()) {
|
||||||
|
groupQuery = getPointGroupQuery(schemaField, count, groupSet);
|
||||||
|
} else {
|
||||||
|
groupQuery = getGroupQuery(field, fieldType, count, groupSet);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -442,13 +453,7 @@ public class ExpandComponent extends SearchComponent implements PluginInfoInitia
|
||||||
String group = charsRef.toString();
|
String group = charsRef.toString();
|
||||||
outMap.add(group, slice);
|
outMap.add(group, slice);
|
||||||
} else {
|
} else {
|
||||||
if(fieldType instanceof TrieIntField || fieldType instanceof TrieLongField ) {
|
outMap.add(numericToString(fieldType, groupValue), slice);
|
||||||
outMap.add(Long.toString(groupValue), slice);
|
|
||||||
} else if(fieldType instanceof TrieFloatField) {
|
|
||||||
outMap.add(Float.toString(Float.intBitsToFloat((int) groupValue)), slice);
|
|
||||||
} else if(fieldType instanceof TrieDoubleField) {
|
|
||||||
outMap.add(Double.toString(Double.longBitsToDouble(groupValue)), slice);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -703,18 +708,10 @@ public class ExpandComponent extends SearchComponent implements PluginInfoInitia
|
||||||
BytesRefBuilder term = new BytesRefBuilder();
|
BytesRefBuilder term = new BytesRefBuilder();
|
||||||
Iterator<LongCursor> it = groupSet.iterator();
|
Iterator<LongCursor> it = groupSet.iterator();
|
||||||
int index = -1;
|
int index = -1;
|
||||||
String stringVal = null;
|
|
||||||
while (it.hasNext()) {
|
while (it.hasNext()) {
|
||||||
LongCursor cursor = it.next();
|
LongCursor cursor = it.next();
|
||||||
if(ft instanceof TrieIntField || ft instanceof TrieLongField) {
|
String stringVal = numericToString(ft, cursor.value);
|
||||||
stringVal = Long.toString(cursor.value);
|
|
||||||
} else {
|
|
||||||
if(ft instanceof TrieFloatField) {
|
|
||||||
stringVal = Float.toString(Float.intBitsToFloat((int)cursor.value));
|
|
||||||
} else {
|
|
||||||
stringVal = Double.toString(Double.longBitsToDouble(cursor.value));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ft.readableToIndexed(stringVal, term);
|
ft.readableToIndexed(stringVal, term);
|
||||||
bytesRefs[++index] = term.toBytesRef();
|
bytesRefs[++index] = term.toBytesRef();
|
||||||
}
|
}
|
||||||
|
@ -722,6 +719,36 @@ public class ExpandComponent extends SearchComponent implements PluginInfoInitia
|
||||||
return new SolrConstantScoreQuery(new QueryWrapperFilter(new TermInSetQuery(fname, bytesRefs)));
|
return new SolrConstantScoreQuery(new QueryWrapperFilter(new TermInSetQuery(fname, bytesRefs)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Query getPointGroupQuery(SchemaField sf,
|
||||||
|
int size,
|
||||||
|
LongHashSet groupSet) {
|
||||||
|
|
||||||
|
Iterator<LongCursor> it = groupSet.iterator();
|
||||||
|
List<String> values = new ArrayList<>(size);
|
||||||
|
FieldType ft = sf.getType();
|
||||||
|
while (it.hasNext()) {
|
||||||
|
LongCursor cursor = it.next();
|
||||||
|
values.add(numericToString(ft, cursor.value));
|
||||||
|
}
|
||||||
|
|
||||||
|
return new SolrConstantScoreQuery(new QueryWrapperFilter(sf.getType().getSetQuery(null, sf, values)));
|
||||||
|
}
|
||||||
|
|
||||||
|
private String numericToString(FieldType fieldType, long val) {
|
||||||
|
if (fieldType.getNumberType() != null) {
|
||||||
|
switch (fieldType.getNumberType()) {
|
||||||
|
case INTEGER:
|
||||||
|
case LONG:
|
||||||
|
return Long.toString(val);
|
||||||
|
case FLOAT:
|
||||||
|
return Float.toString(Float.intBitsToFloat((int)val));
|
||||||
|
case DOUBLE:
|
||||||
|
return Double.toString(Double.longBitsToDouble(val));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
throw new IllegalArgumentException("FieldType must be INT,LONG,FLOAT,DOUBLE found " + fieldType);
|
||||||
|
}
|
||||||
|
|
||||||
private Query getGroupQuery(String fname,
|
private Query getGroupQuery(String fname,
|
||||||
int size,
|
int size,
|
||||||
IntObjectHashMap<BytesRef> ordBytes) throws Exception {
|
IntObjectHashMap<BytesRef> ordBytes) throws Exception {
|
||||||
|
|
|
@ -21,14 +21,12 @@ import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
import org.apache.solr.SolrTestCaseJ4.SuppressPointFields;
|
|
||||||
import org.apache.solr.common.params.ModifiableSolrParams;
|
import org.apache.solr.common.params.ModifiableSolrParams;
|
||||||
import org.apache.solr.search.CollapsingQParserPlugin;
|
import org.apache.solr.search.CollapsingQParserPlugin;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
@SuppressPointFields
|
|
||||||
public class TestExpandComponent extends SolrTestCaseJ4 {
|
public class TestExpandComponent extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
|
|
Loading…
Reference in New Issue