public class TermFirstPassGroupingCollector extends AbstractFirstPassGroupingCollector<String>
AbstractFirstPassGroupingCollector
that groups based on
field values and more specifically uses FieldCache.StringIndex
to collect groups.Constructor and Description |
---|
TermFirstPassGroupingCollector(String groupField,
Sort groupSort,
int topNGroups)
Create the first pass collector.
|
Modifier and Type | Method and Description |
---|---|
protected String |
copyDocGroupValue(String groupValue,
String reuse)
Returns a copy of the specified group value by creating a new instance and copying the value from the specified
groupValue in the new instance.
|
protected String |
getDocGroupValue(int doc)
Returns the group value for the specified doc.
|
void |
setNextReader(IndexReader reader,
int docBase)
Called before collecting from each IndexReader.
|
acceptsDocsOutOfOrder, collect, getTopGroups, setScorer
public TermFirstPassGroupingCollector(String groupField, Sort groupSort, int topNGroups) throws IOException
groupField
- The field used to group
documents. This field must be single-valued and
indexed (FieldCache is used to access its value
per-document).groupSort
- The Sort
used to sort the
groups. The top sorted document within each group
according to groupSort, determines how that group
sorts against other groups. This must be non-null,
ie, if you want to groupSort by relevance use
Sort.RELEVANCE.topNGroups
- How many top groups to keep.IOException
- When I/O related errors occurprotected String getDocGroupValue(int doc)
AbstractFirstPassGroupingCollector
getDocGroupValue
in class AbstractFirstPassGroupingCollector<String>
doc
- The specified docprotected String copyDocGroupValue(String groupValue, String reuse)
AbstractFirstPassGroupingCollector
copyDocGroupValue
in class AbstractFirstPassGroupingCollector<String>
groupValue
- The group value to copyreuse
- Optionally a reuse instance to prevent a new instance creationpublic void setNextReader(IndexReader reader, int docBase) throws IOException
Collector
Collector.collect(int)
will correspond to reader.
Add docBase to the current IndexReaders internal document id to re-base ids
in Collector.collect(int)
.setNextReader
in class AbstractFirstPassGroupingCollector<String>
reader
- next IndexReaderIOException