Enum datafusion_expr::expr::GroupingSet
source · pub enum GroupingSet {
Rollup(Vec<Expr>),
Cube(Vec<Expr>),
GroupingSets(Vec<Vec<Expr>>),
}
Expand description
Grouping sets
See https://www.postgresql.org/docs/current/queries-table-expressions.html#QUERIES-GROUPING-SETS for Postgres definition. See https://spark.apache.org/docs/latest/sql-ref-syntax-qry-select-groupby.html for Apache Spark definition.
Variants§
Rollup(Vec<Expr>)
Rollup grouping sets
Cube(Vec<Expr>)
Cube grouping sets
GroupingSets(Vec<Vec<Expr>>)
User-defined grouping sets
Implementations§
source§impl GroupingSet
impl GroupingSet
sourcepub fn distinct_expr(&self) -> Vec<&Expr>
pub fn distinct_expr(&self) -> Vec<&Expr>
Return all distinct exprs in the grouping set. For CUBE
and ROLLUP
this
is just the underlying list of exprs. For GROUPING SET
we need to deduplicate
the exprs in the underlying sets.
Trait Implementations§
source§impl Clone for GroupingSet
impl Clone for GroupingSet
source§fn clone(&self) -> GroupingSet
fn clone(&self) -> GroupingSet
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Debug for GroupingSet
impl Debug for GroupingSet
source§impl Hash for GroupingSet
impl Hash for GroupingSet
source§impl PartialEq for GroupingSet
impl PartialEq for GroupingSet
impl Eq for GroupingSet
impl StructuralPartialEq for GroupingSet
Auto Trait Implementations§
impl Freeze for GroupingSet
impl !RefUnwindSafe for GroupingSet
impl Send for GroupingSet
impl Sync for GroupingSet
impl Unpin for GroupingSet
impl !UnwindSafe for GroupingSet
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)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.