Struct datafusion_physical_expr::expressions::LikeExpr
source · pub struct LikeExpr { /* private fields */ }
Implementations§
source§impl LikeExpr
impl LikeExpr
pub fn new( negated: bool, case_insensitive: bool, expr: Arc<dyn PhysicalExpr>, pattern: Arc<dyn PhysicalExpr> ) -> Self
sourcepub fn case_insensitive(&self) -> bool
pub fn case_insensitive(&self) -> bool
Is case insensitive
sourcepub fn expr(&self) -> &Arc<dyn PhysicalExpr>
pub fn expr(&self) -> &Arc<dyn PhysicalExpr>
Input expression
sourcepub fn pattern(&self) -> &Arc<dyn PhysicalExpr>
pub fn pattern(&self) -> &Arc<dyn PhysicalExpr>
Pattern expression
Trait Implementations§
source§impl PartialEq<dyn Any> for LikeExpr
impl PartialEq<dyn Any> for LikeExpr
source§impl PhysicalExpr for LikeExpr
impl PhysicalExpr for LikeExpr
source§fn as_any(&self) -> &dyn Any
fn as_any(&self) -> &dyn Any
Returns the physical expression as
Any
so that it can be
downcast to a specific implementation.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_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
source§fn evaluate_bounds(
&self,
_children: &[&Interval]
) -> Result<Interval, DataFusionError>
fn evaluate_bounds( &self, _children: &[&Interval] ) -> Result<Interval, DataFusionError>
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>>, DataFusionError>
fn propagate_constraints( &self, _interval: &Interval, _children: &[&Interval] ) -> Result<Option<Vec<Interval>>, DataFusionError>
Updates bounds for child expressions, given a known interval for this
expression. Read more
source§fn get_ordering(&self, _children: &[SortProperties]) -> SortProperties
fn get_ordering(&self, _children: &[SortProperties]) -> SortProperties
The order information of a PhysicalExpr can be estimated from its children.
This is especially helpful for projection expressions. If we can ensure that the
order of a PhysicalExpr to project matches with the order of SortExec, we can
eliminate that SortExecs. Read more
Auto Trait Implementations§
impl Freeze for LikeExpr
impl !RefUnwindSafe for LikeExpr
impl Send for LikeExpr
impl Sync for LikeExpr
impl Unpin for LikeExpr
impl !UnwindSafe for LikeExpr
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<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