Package org.apache.druid.segment.filter
Class OrFilter
- java.lang.Object
-
- org.apache.druid.segment.filter.OrFilter
-
- All Implemented Interfaces:
BooleanFilter,Filter
public class OrFilter extends Object implements BooleanFilter
Logical OR filter operation
-
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description booleancanVectorizeMatcher(ColumnInspector inspector)Returns true if this filter can produce a vectorized matcher from its "makeVectorMatcher" method.booleanequals(Object o)BitmapColumnIndexgetBitmapColumnIndex(ColumnIndexSelector selector)Returns aBitmapColumnIndexif this filter supports using a bitmap index for filtering for the given inputColumnIndexSelector.LinkedHashSet<Filter>getFilters()Returns the child filters for this filter.inthashCode()<T> FilterBundlemakeFilterBundle(ColumnIndexSelector columnIndexSelector, BitmapResultFactory<T> bitmapResultFactory, int applyRowCount, int totalRowCount, boolean includeUnknown)Compute indexes and build a containerFilterBundleto be used duringCursororVectorCursorcreation, combining the computed outputs ofFilter.getBitmapColumnIndex(ColumnIndexSelector)as well as references toFilter.makeMatcher(ColumnSelectorFactory)andFilter.makeVectorMatcher(VectorColumnSelectorFactory).ValueMatchermakeMatcher(ColumnSelectorFactory factory)Get aValueMatcherthat applies this filter to row values.VectorValueMatchermakeVectorMatcher(VectorColumnSelectorFactory factory)Get aVectorValueMatcherthat applies this filter to row vectors.FilterrewriteRequiredColumns(Map<String,String> columnRewrites)Return a copy of this filter that is identical to the this filter except that it operates on different columns, based on a renaming map where the key is the column to be renamed in the filter, and the value is the new column name.booleansupportsRequiredColumnRewrite()Returns true is this filter is able to return a copy of this filter that is identical to this filter except that it operates on different columns, based on a renaming map.StringtoString()-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.apache.druid.query.filter.BooleanFilter
getRequiredColumns
-
-
-
-
Constructor Detail
-
OrFilter
public OrFilter(LinkedHashSet<Filter> filters)
-
-
Method Detail
-
makeFilterBundle
public <T> FilterBundle makeFilterBundle(ColumnIndexSelector columnIndexSelector, BitmapResultFactory<T> bitmapResultFactory, int applyRowCount, int totalRowCount, boolean includeUnknown)
Description copied from interface:FilterCompute indexes and build a containerFilterBundleto be used duringCursororVectorCursorcreation, combining the computed outputs ofFilter.getBitmapColumnIndex(ColumnIndexSelector)as well as references toFilter.makeMatcher(ColumnSelectorFactory)andFilter.makeVectorMatcher(VectorColumnSelectorFactory).Filters populating the
FilterBundlecontainer should only set the values which MUST be evaluated by the cursor. If both are set, the cursor will effectively perform a logical AND to combine them. SeeFilterBundlefor additional details.- Specified by:
makeFilterBundlein interfaceFilter- Type Parameters:
T- - Type ofBitmapResultFactoryresults,ImmutableBitmapby default- Parameters:
columnIndexSelector- - providesColumnIndexSupplierto fetch column indexes andBitmapFactoryto manipulate thembitmapResultFactory- - wrapper forImmutableBitmapoperations to tie intoQueryMetricsand build the output indexesapplyRowCount- - upper bound on number of rows this filter would be applied to, after removing rows short-circuited by prior bundle operations. For example, given "x AND y", if "x" is resolved using an index, then "y" will receive the number of rows that matched the filter "x". As another example, given "x OR y", if "x" is resolved using an index, then "y" will receive the number of rows that did *not* match the filter "x".totalRowCount- - total number of rows to be scanned if no indexes are appliedincludeUnknown- - mapping for Druid native two state logic system into SQL three-state logic system. If set to true, bitmaps returned by this method should include true bits for any rows where the matching result is 'unknown', such as from the input being null valued. SeeNullHandling.useThreeValueLogic()- Returns:
- -
FilterBundlecontaining any indexes and/or matchers that are needed to build a cursor
-
getBitmapColumnIndex
@Nullable public BitmapColumnIndex getBitmapColumnIndex(ColumnIndexSelector selector)
Description copied from interface:FilterReturns aBitmapColumnIndexif this filter supports using a bitmap index for filtering for the given inputColumnIndexSelector. TheBitmapColumnIndexcan be used to compute into a bitmap indicating rows that match this filter resultBitmapColumnIndex.computeBitmapResult(BitmapResultFactory, boolean), or examine details about the index prior to computing it, viaBitmapColumnIndex.getIndexCapabilities().- Specified by:
getBitmapColumnIndexin interfaceFilter- Parameters:
selector- Object used to create BitmapColumnIndex- Returns:
- BitmapColumnIndex that can build ImmutableBitmap of matched row numbers
-
makeMatcher
public ValueMatcher makeMatcher(ColumnSelectorFactory factory)
Description copied from interface:FilterGet aValueMatcherthat applies this filter to row values.- Specified by:
makeMatcherin interfaceFilter- Parameters:
factory- Object used to create ValueMatchers- Returns:
- ValueMatcher that applies this filter to row values.
-
makeVectorMatcher
public VectorValueMatcher makeVectorMatcher(VectorColumnSelectorFactory factory)
Description copied from interface:FilterGet aVectorValueMatcherthat applies this filter to row vectors.- Specified by:
makeVectorMatcherin interfaceFilter- Parameters:
factory- Object used to create ValueMatchers- Returns:
- VectorValueMatcher that applies this filter to row vectors.
-
canVectorizeMatcher
public boolean canVectorizeMatcher(ColumnInspector inspector)
Description copied from interface:FilterReturns true if this filter can produce a vectorized matcher from its "makeVectorMatcher" method.- Specified by:
canVectorizeMatcherin interfaceFilter- Parameters:
inspector- Supplies type information for the selectors this filter will match against
-
getFilters
public LinkedHashSet<Filter> getFilters()
Description copied from interface:BooleanFilterReturns the child filters for this filter. This is a LinkedHashSet because we don't want duplicates, but the order is also important in some cases (such as when filters are provided in an order that encourages short-circuiting.)- Specified by:
getFiltersin interfaceBooleanFilter
-
supportsRequiredColumnRewrite
public boolean supportsRequiredColumnRewrite()
Description copied from interface:FilterReturns true is this filter is able to return a copy of this filter that is identical to this filter except that it operates on different columns, based on a renaming map.- Specified by:
supportsRequiredColumnRewritein interfaceFilter
-
rewriteRequiredColumns
public Filter rewriteRequiredColumns(Map<String,String> columnRewrites)
Description copied from interface:FilterReturn a copy of this filter that is identical to the this filter except that it operates on different columns, based on a renaming map where the key is the column to be renamed in the filter, and the value is the new column name. For example, if I have a filter (A = hello), and I have a renaming map (A -> B), this should return the filter (B = hello)- Specified by:
rewriteRequiredColumnsin interfaceFilter- Parameters:
columnRewrites- Column rewrite map- Returns:
- Copy of this filter that operates on new columns based on the rewrite map
-
-