Comments (5)
Great idea @ClSlaid
Thanks to @AbrarNitk we have a first version of LogicalPlanBuilder::from(arc_input)
in #10466 🙏
I think we should merge that PR and then make a second PR (and maybe a second ticket) about switching the internal representation from
datafusion/datafusion/expr/src/logical_plan/builder.rs
Lines 98 to 101 in 8cc92a9
To
pub struct LogicalPlanBuilder {
plan: Arc<LogicalPlan>,
}
from arrow-datafusion.
I suggest not call unwrap_arc
until the built LogicalPlan
really requires the ownership of a LogicalPlan
.
In most occasions, LogicalPlan
contains an input: Arc<LogicalPlan>
, and sometimes we will have to construct LogicalPlanBuilder
from it. This will lead to a clone, or (99 percent likely) avoiding that with unwrap_arc
.
Meanwhile, most of the LogicalPlan
s constructed by the builder place the plan in Arc
s again. This then causes another clone.
There must be a way to seamlessly moving the input: Arc<LogicalPlan>
into rewritten plans, and it would be no clone in most occasions, and at most one clone be committed.
from arrow-datafusion.
That is an interesting point @ClSlaid
So perhaps you are suggesting LogicalPlanBuilder
has an Arc<LogicalPlan>
as its internal state (rather than a LogicalPlan
)
from arrow-datafusion.
So perhaps you are suggesting
LogicalPlanBuilder
has anArc<LogicalPlan>
as its internal state (rather than aLogicalPlan
)
This is surely the most straight forward way.
from arrow-datafusion.
Filed #10485 to track the internal representation change
from arrow-datafusion.
Related Issues (20)
- Add an example of how to use the SQL parser/unparser API HOT 2
- Support Substrait VirtualTables
- Discussion: make it easier for specify SQL --> function translation HOT 7
- Create a DataFusion blog HOT 3
- `analysis.rs` bounds check panic HOT 5
- AggregateUDF expression API design HOT 2
- Example for building an external index for parquet files HOT 6
- `array_slice` can't correctly handle NULL parameters or some edge cases
- Add an example of how to convert LogicalPlan to/from SQL Strings
- Cast from string to date with "/" HOT 2
- error: this arithmetic operation will overflow (on i386)
- REmove workaround for `COUNT(*)` in subquery decorrelation code
- Make SQL strings generated from `Expr`s "prettier" HOT 11
- Dynamic schema for custom TableProvider HOT 4
- ScalarValue serialization does not handle nested dictionary values
- Using `Expr::field` panics HOT 3
- Improve signature of `get_field` is function
- UserDefinedLogicalNode::from_template does not return a Result<...> >
- UserDefindedLogicalNode::from_template does not return a Result<...>. HOT 3
- Row groups are read out of order or with completely different values HOT 9
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.