Class AbstractParquetGroupScan.RowGroupScanFilterer<B extends AbstractParquetGroupScan.RowGroupScanFilterer<B>>
java.lang.Object
org.apache.drill.exec.physical.base.AbstractGroupScanWithMetadata.GroupScanWithMetadataFilterer<B>
org.apache.drill.exec.store.parquet.AbstractParquetGroupScan.RowGroupScanFilterer<B>
- Enclosing class:
- AbstractParquetGroupScan
protected abstract static class AbstractParquetGroupScan.RowGroupScanFilterer<B extends AbstractParquetGroupScan.RowGroupScanFilterer<B>>
extends AbstractGroupScanWithMetadata.GroupScanWithMetadataFilterer<B>
This class is responsible for filtering different metadata levels including row group level.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected com.google.common.collect.Multimap<org.apache.hadoop.fs.Path, RowGroupMetadata> Fields inherited from class org.apache.drill.exec.physical.base.AbstractGroupScanWithMetadata.GroupScanWithMetadataFilterercontext, files, filterExpression, limit, matchAllMetadata, nonInterestingColumnsMetadata, overflowLevel, partitions, segments, source, tableMetadata, tableSchema, udfUtilities
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionbuild()Constructs required implementation ofAbstractGroupScanWithMetadatawith filtered metadata.protected voidfilterFileMetadata(OptionManager optionManager, FilterPredicate<?> filterPredicate, Set<SchemaPath> schemaPathsInExpr) Produces filtering of metadata at file level.protected voidfilterRowGroupMetadata(OptionManager optionManager, FilterPredicate<?> filterPredicate) Produces filtering of metadata at row group level.protected BgetFiltered(OptionManager optionManager, FilterPredicate<?> filterPredicate) Produces filtering of metadata and returnsAbstractGroupScanWithMetadata.GroupScanWithMetadataFiltererto construct resulting group scan.protected abstract AbstractParquetGroupScanReturns newAbstractParquetGroupScaninstance to be populated with filtered metadata from thisAbstractParquetGroupScan.RowGroupScanFiltererinstance.com.google.common.collect.Multimap<org.apache.hadoop.fs.Path, RowGroupMetadata> protected static <T extends BaseMetadata & LocationProvider>
 com.google.common.collect.Multimap<org.apache.hadoop.fs.Path, T> pruneForSegments(com.google.common.collect.Multimap<org.apache.hadoop.fs.Path, T> metadataToPrune, Map<org.apache.hadoop.fs.Path, SegmentMetadata> filteredSegmentMetadata) Removes metadata which does not belong to any of segments in metadata list.rowGroups(com.google.common.collect.Multimap<org.apache.hadoop.fs.Path, RowGroupMetadata> rowGroups) Methods inherited from class org.apache.drill.exec.physical.base.AbstractGroupScanWithMetadata.GroupScanWithMetadataFilterercontext, files, filterAndGetMetadata, filterExpression, filterPartitionMetadata, filterSegmentMetadata, filterTableMetadata, getFiles, getImplicitColumnStatistics, getOverflowLevel, getPartitions, getSegments, getTableMetadata, isMatchAllMetadata, limit, matching, nonInterestingColumns, overflow, partitions, pruneForSegments, pruneForSegments, schema, segments, self, table, udfUtilities
- 
Field Details- 
rowGroups
 
- 
- 
Constructor Details- 
RowGroupScanFilterer
 
- 
- 
Method Details- 
rowGroupspublic B rowGroups(com.google.common.collect.Multimap<org.apache.hadoop.fs.Path, RowGroupMetadata> rowGroups) 
- 
getNewScanReturns newAbstractParquetGroupScaninstance to be populated with filtered metadata from thisAbstractParquetGroupScan.RowGroupScanFiltererinstance.- Returns:
- new AbstractParquetGroupScaninstance
 
- 
getRowGroupspublic com.google.common.collect.Multimap<org.apache.hadoop.fs.Path,RowGroupMetadata> getRowGroups()
- 
buildDescription copied from class:AbstractGroupScanWithMetadata.GroupScanWithMetadataFiltererConstructs required implementation ofAbstractGroupScanWithMetadatawith filtered metadata.- Specified by:
- buildin class- AbstractGroupScanWithMetadata.GroupScanWithMetadataFilterer<B extends AbstractParquetGroupScan.RowGroupScanFilterer<B>>
- Returns:
- implementation of AbstractGroupScanWithMetadatawith filtered metadata
 
- 
getFilteredDescription copied from class:AbstractGroupScanWithMetadata.GroupScanWithMetadataFiltererProduces filtering of metadata and returnsAbstractGroupScanWithMetadata.GroupScanWithMetadataFiltererto construct resulting group scan.- Overrides:
- getFilteredin class- AbstractGroupScanWithMetadata.GroupScanWithMetadataFilterer<B extends AbstractParquetGroupScan.RowGroupScanFilterer<B>>
- Parameters:
- optionManager- option manager
- filterPredicate- filter expression
- Returns:
- this instance with filtered metadata
 
- 
filterRowGroupMetadataprotected void filterRowGroupMetadata(OptionManager optionManager, FilterPredicate<?> filterPredicate) Produces filtering of metadata at row group level.- Parameters:
- optionManager- option manager
- filterPredicate- filter expression
 
- 
filterFileMetadataprotected void filterFileMetadata(OptionManager optionManager, FilterPredicate<?> filterPredicate, Set<SchemaPath> schemaPathsInExpr) Produces filtering of metadata at file level.- Overrides:
- filterFileMetadatain class- AbstractGroupScanWithMetadata.GroupScanWithMetadataFilterer<B extends AbstractParquetGroupScan.RowGroupScanFilterer<B>>
- Parameters:
- optionManager- option manager
- filterPredicate- filter expression
- schemaPathsInExpr- columns used in filter expression
 
- 
pruneForSegmentsprotected static <T extends BaseMetadata & LocationProvider> com.google.common.collect.Multimap<org.apache.hadoop.fs.Path,T> pruneForSegments(com.google.common.collect.Multimap<org.apache.hadoop.fs.Path, T> metadataToPrune, Map<org.apache.hadoop.fs.Path, SegmentMetadata> filteredSegmentMetadata) Removes metadata which does not belong to any of segments in metadata list.- Type Parameters:
- T- type of metadata to filter
- Parameters:
- metadataToPrune- list of metadata which should be pruned
- filteredSegmentMetadata- list of segment metadata which was pruned
- Returns:
- multimap with metadata which belongs to pruned segments
 
 
-