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 duplicate 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§impl PartialOrd for GroupingSet
 
impl PartialOrd 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§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