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, setScorerpublic 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)
AbstractFirstPassGroupingCollectorgetDocGroupValue in class AbstractFirstPassGroupingCollector<String>doc - The specified docprotected String copyDocGroupValue(String groupValue, String reuse)
AbstractFirstPassGroupingCollectorcopyDocGroupValue 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
CollectorCollector.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