Class ExpressionLambdaAggregator
- java.lang.Object
-
- org.apache.druid.query.aggregation.ExpressionLambdaAggregator
-
- All Implemented Interfaces:
Closeable,AutoCloseable,Aggregator
public class ExpressionLambdaAggregator extends Object implements Aggregator
-
-
Constructor Summary
Constructors Constructor Description ExpressionLambdaAggregator(ExpressionLambdaAggregatorFactory.FactorizePlan thePlan, int maxSizeBytes)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaggregate()Performs aggregation.voidclose()Objectget()doublegetDouble()The default implementation castsAggregator.getFloat()to double.floatgetFloat()longgetLong()booleanisNull()returns true if aggregator's output type is primitive long/double/float and aggregated value is null, but when aggregated output type is Object, this method always returns false, and users are advised to check nullability for the object returned byAggregator.get()method.-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.apache.druid.query.aggregation.Aggregator
aggregateWithSize
-
-
-
-
Constructor Detail
-
ExpressionLambdaAggregator
public ExpressionLambdaAggregator(ExpressionLambdaAggregatorFactory.FactorizePlan thePlan, int maxSizeBytes)
-
-
Method Detail
-
aggregate
public void aggregate()
Description copied from interface:AggregatorPerforms aggregation.- Specified by:
aggregatein interfaceAggregator
-
get
@Nullable public Object get()
- Specified by:
getin interfaceAggregator
-
getFloat
public float getFloat()
- Specified by:
getFloatin interfaceAggregator
-
getLong
public long getLong()
- Specified by:
getLongin interfaceAggregator
-
getDouble
public double getDouble()
Description copied from interface:AggregatorThe default implementation castsAggregator.getFloat()to double. This default method is added to enable smooth backward compatibility, please re-implement it if your aggregators work with numeric double columns.- Specified by:
getDoublein interfaceAggregator
-
isNull
public boolean isNull()
Description copied from interface:Aggregatorreturns true if aggregator's output type is primitive long/double/float and aggregated value is null, but when aggregated output type is Object, this method always returns false, and users are advised to check nullability for the object returned byAggregator.get()method. The default implementation always return false to enable smooth backward compatibility, re-implement if your aggregator is nullable.- Specified by:
isNullin interfaceAggregator
-
close
public void close()
- Specified by:
closein interfaceAggregator- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable
-
-