Comments (5)
Hi @alamb, I am wondering whether is there a way to implement the cube
and 'rollup' functions easily. the inner vector is expanded in the planner.
from arrow-datafusion.
Hi @xinlifoobar - another thing that we could potentially do is to work at this from the SQL statement level (rather than the Expr level)
As in implement a round trip test like this for a query with a grouping set:
https://github.com/apache/datafusion/blob/main/datafusion/sql/tests/sql_integration.rs#L4678-L4708
from arrow-datafusion.
I think from the Vec<Expr>
could not mapping back to the only unique Vec<Vec<Expr>>
and hence unparse the cube statement would be difficult. How about store another copy of origin Vec in the Cube and Rollup instance? i.e.,
pub enum GroupingSet {
/// Rollup grouping sets
Rollup(Vec<Expr>, Vec<Vec<Expr>>),
/// Cube grouping sets
Cube(Vec<Expr>, Vec<Vec<Expr>>),
/// User-defined grouping sets
GroupingSets(Vec<Vec<Expr>>),
}
from arrow-datafusion.
I made a mistake about the previous statements. The vector of cube and rollout is not expanded so the implement could be easy.
https://github.com/apache/datafusion/blob/main/datafusion/sql/src/expr/grouping_set.rs#L42-L81
from arrow-datafusion.
Thanks again @xinlifoobar
from arrow-datafusion.
Related Issues (20)
- How to merge multiple data sources and deduplicate based on certain fields?
- Alias `APPROX_PERCENTILE_CONT` as `PERCENTILE_CONT`? HOT 1
- `PartialOrd` for structs with incomparable fields HOT 2
- Fix unparsing OFFSET
- Implement nested expression support in Substrait
- Panic on aggregations on struct of dictionaries HOT 3
- parquet: page_index/pushdown metrics names are inconsistent with row_group metrics
- parquet: Pushdown-related metrics are not documented
- parquet: Add an option to not parse the Page Index on each query
- [EPIC] Easier extension configuration SessionState / SessionConfig
- Make `SessionContext::enable_url_table` consume `self`
- Support adding a single new table factory to `SessionStateBuilder` HOT 3
- Support Register object stores via SessionStateBuilder HOT 2
- Make it clearer that `RuntimeEnv::new()` is fallable HOT 2
- Implement `Debug` for `SessionStateBuilder HOT 3
- Sort Pushdown Causes an Invalid Plan
- Potential regression in Schema / nullability calculations after upgrade to 42.0.0
- EXPLAIN ANALYZE metrics should be sorted alphabetically
- Property based testing to detect more (subtle and edge cases) bugs
- Incorrect results when using grouping sets with data containing nulls
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from arrow-datafusion.