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<GroupingSet> for GroupingSet
impl PartialEq<GroupingSet> 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 Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§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 Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.