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
source§fn eq(&self, other: &GroupingSet) -> bool
 
fn eq(&self, other: &GroupingSet) -> bool
This method tests for 
self and other values to be equal, and is used
by ==.impl Eq for GroupingSet
impl StructuralEq for GroupingSet
impl StructuralPartialEq for GroupingSet
Auto Trait Implementations§
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
§impl<Q, K> Equivalent<K> for Q
 
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
 
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<Q, K> Equivalent<K> for Q
 
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
 
fn equivalent(&self, key: &K) -> bool
Compare self to 
key and return true if they are equal.