pub struct ScalarFunctionExpr { /* private fields */ }
Expand description
Physical expression of a scalar function
Implementations§
Source§impl ScalarFunctionExpr
impl ScalarFunctionExpr
Sourcepub fn new(
name: &str,
fun: Arc<ScalarUDF>,
args: Vec<Arc<dyn PhysicalExpr>>,
return_type: DataType,
) -> Self
pub fn new( name: &str, fun: Arc<ScalarUDF>, args: Vec<Arc<dyn PhysicalExpr>>, return_type: DataType, ) -> Self
Create a new Scalar function
Sourcepub fn try_new(
fun: Arc<ScalarUDF>,
args: Vec<Arc<dyn PhysicalExpr>>,
schema: &Schema,
) -> Result<Self>
pub fn try_new( fun: Arc<ScalarUDF>, args: Vec<Arc<dyn PhysicalExpr>>, schema: &Schema, ) -> Result<Self>
Create a new Scalar function
Sourcepub fn args(&self) -> &[Arc<dyn PhysicalExpr>]
pub fn args(&self) -> &[Arc<dyn PhysicalExpr>]
Input arguments
Sourcepub fn return_type(&self) -> &DataType
pub fn return_type(&self) -> &DataType
Data type produced by this expression
pub fn with_nullable(self, nullable: bool) -> Self
pub fn nullable(&self) -> bool
Trait Implementations§
Source§impl Debug for ScalarFunctionExpr
impl Debug for ScalarFunctionExpr
Source§impl Display for ScalarFunctionExpr
impl Display for ScalarFunctionExpr
Source§impl Hash for ScalarFunctionExpr
impl Hash for ScalarFunctionExpr
Source§impl PartialEq for ScalarFunctionExpr
impl PartialEq for ScalarFunctionExpr
Source§impl PhysicalExpr for ScalarFunctionExpr
impl PhysicalExpr for ScalarFunctionExpr
Source§fn data_type(&self, _input_schema: &Schema) -> Result<DataType>
fn data_type(&self, _input_schema: &Schema) -> Result<DataType>
Get the data type of this expression, given the schema of the input
Source§fn nullable(&self, _input_schema: &Schema) -> Result<bool>
fn nullable(&self, _input_schema: &Schema) -> Result<bool>
Determine whether this expression is nullable, given the schema of the input
Source§fn evaluate(&self, batch: &RecordBatch) -> Result<ColumnarValue>
fn evaluate(&self, batch: &RecordBatch) -> Result<ColumnarValue>
Evaluate an expression against a RecordBatch
Source§fn children(&self) -> Vec<&Arc<dyn PhysicalExpr>>
fn children(&self) -> Vec<&Arc<dyn PhysicalExpr>>
Get a list of child PhysicalExpr that provide the input for this expr.
Source§fn with_new_children(
self: Arc<Self>,
children: Vec<Arc<dyn PhysicalExpr>>,
) -> Result<Arc<dyn PhysicalExpr>>
fn with_new_children( self: Arc<Self>, children: Vec<Arc<dyn PhysicalExpr>>, ) -> Result<Arc<dyn PhysicalExpr>>
Returns a new PhysicalExpr where all children were replaced by new exprs.
Source§fn evaluate_bounds(&self, children: &[&Interval]) -> Result<Interval>
fn evaluate_bounds(&self, children: &[&Interval]) -> Result<Interval>
Computes the output interval for the expression, given the input
intervals. Read more
Source§fn propagate_constraints(
&self,
interval: &Interval,
children: &[&Interval],
) -> Result<Option<Vec<Interval>>>
fn propagate_constraints( &self, interval: &Interval, children: &[&Interval], ) -> Result<Option<Vec<Interval>>>
Updates bounds for child expressions, given a known interval for this
expression. Read more
Source§fn get_properties(&self, children: &[ExprProperties]) -> Result<ExprProperties>
fn get_properties(&self, children: &[ExprProperties]) -> Result<ExprProperties>
Calculates the properties of this
PhysicalExpr
based on its
children’s properties (i.e. order and range), recursively aggregating
the information from its children. In cases where the PhysicalExpr
has no children (e.g., Literal
or Column
), these properties should
be specified externally, as the function defaults to unknown properties.Source§fn evaluate_selection(
&self,
batch: &RecordBatch,
selection: &BooleanArray,
) -> Result<ColumnarValue, DataFusionError>
fn evaluate_selection( &self, batch: &RecordBatch, selection: &BooleanArray, ) -> Result<ColumnarValue, DataFusionError>
Evaluate an expression against a RecordBatch after first applying a
validity array
impl Eq for ScalarFunctionExpr
impl StructuralPartialEq for ScalarFunctionExpr
Auto Trait Implementations§
impl Freeze for ScalarFunctionExpr
impl !RefUnwindSafe for ScalarFunctionExpr
impl Send for ScalarFunctionExpr
impl Sync for ScalarFunctionExpr
impl Unpin for ScalarFunctionExpr
impl !UnwindSafe for ScalarFunctionExpr
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more