Package com.illumon.iris.db.v2.dataindex
Class DiskBackedDeferredGroupingProvider<DATA_TYPE>
java.lang.Object
com.illumon.iris.db.v2.dataindex.MemoizingGroupingProvider
com.illumon.iris.db.v2.dataindex.DiskBackedDeferredGroupingProvider<DATA_TYPE>
- All Implemented Interfaces:
GroupingProvider,KeyRangeGroupingProvider<DATA_TYPE>
public class DiskBackedDeferredGroupingProvider<DATA_TYPE> extends MemoizingGroupingProvider implements KeyRangeGroupingProvider<DATA_TYPE>
Grouping provider that loads column location metadata and assembles grouping indexes lazily on demand.
-
Constructor Summary
Constructors Constructor Description DiskBackedDeferredGroupingProvider(com.illumon.dataobjects.ColumnDefinition<DATA_TYPE> columnDefinition, com.fishlib.io.logger.Logger log) -
Method Summary
Modifier and Type Method Description voidaddSource(ColumnLocation columnLocation, long firstKey, long lastKey)Add a column location for consideration when constructing groupings.GroupingBuildergetGroupingBuilder()Get aGroupingBuildersuitable for creating groups with specific properties.booleanhasGrouping()Check if this provider is able to create a grouping or not.Methods inherited from class com.illumon.iris.db.v2.dataindex.MemoizingGroupingProvider
clearMemoizedGroupings, memoizeGrouping
-
Constructor Details
-
DiskBackedDeferredGroupingProvider
public DiskBackedDeferredGroupingProvider(@NotNull com.illumon.dataobjects.ColumnDefinition<DATA_TYPE> columnDefinition, @NotNull com.fishlib.io.logger.Logger log)
-
-
Method Details
-
addSource
Description copied from interface:KeyRangeGroupingProviderAdd a column location for consideration when constructing groupings.- Specified by:
addSourcein interfaceKeyRangeGroupingProvider<DATA_TYPE>- Parameters:
columnLocation- The column location to addfirstKey- The first key in the range for this column locationlastKey- The last key in the range for this column location (inclusive)
-
getGroupingBuilder
Description copied from interface:GroupingProviderGet aGroupingBuildersuitable for creating groups with specific properties.- Specified by:
getGroupingBuilderin interfaceGroupingProvider- Returns:
- a
GroupingBuilder
-
hasGrouping
public boolean hasGrouping()Description copied from interface:GroupingProviderCheck if this provider is able to create a grouping or not.- Specified by:
hasGroupingin interfaceGroupingProvider- Returns:
- true if this provider can create a grouping.
-