-
- Downloads
[SPARK-13671] [SPARK-13311] [SQL] Use different physical plans for RDD and data sources
## What changes were proposed in this pull request? This PR split the PhysicalRDD into two classes, PhysicalRDD and PhysicalScan. PhysicalRDD is used for DataFrames that is created from existing RDD. PhysicalScan is used for DataFrame that is created from data sources. This enable use to apply different optimization on both of them. Also fix the problem for sameResult() on two DataSourceScan. Also fix the equality check to toString for `In`. It's better to use Seq there, but we can't break this public API (sad). ## How was this patch tested? Existing tests. Manually tested with TPCDS query Q59 and Q64, all those duplicated exchanges can be re-used now, also saw there are 40+% performance improvement (saving half of the scan). Author: Davies Liu <davies@databricks.com> Closes #11514 from davies/existing_rdd.
Showing
- python/pyspark/sql/dataframe.py 1 addition, 2 deletionspython/pyspark/sql/dataframe.py
- sql/catalyst/src/main/scala/org/apache/spark/sql/catalyst/plans/QueryPlan.scala 6 additions, 6 deletions...scala/org/apache/spark/sql/catalyst/plans/QueryPlan.scala
- sql/core/src/main/scala/org/apache/spark/sql/execution/ExistingRDD.scala 66 additions, 41 deletions...in/scala/org/apache/spark/sql/execution/ExistingRDD.scala
- sql/core/src/main/scala/org/apache/spark/sql/execution/WholeStageCodegen.scala 1 addition, 0 deletions...la/org/apache/spark/sql/execution/WholeStageCodegen.scala
- sql/core/src/main/scala/org/apache/spark/sql/execution/datasources/DataSourceStrategy.scala 4 additions, 4 deletions.../spark/sql/execution/datasources/DataSourceStrategy.scala
- sql/core/src/main/scala/org/apache/spark/sql/execution/ui/SparkPlanGraph.scala 5 additions, 1 deletion...la/org/apache/spark/sql/execution/ui/SparkPlanGraph.scala
- sql/core/src/main/scala/org/apache/spark/sql/sources/filters.scala 18 additions, 1 deletion...src/main/scala/org/apache/spark/sql/sources/filters.scala
- sql/core/src/test/scala/org/apache/spark/sql/jdbc/JDBCSuite.scala 3 additions, 3 deletions.../src/test/scala/org/apache/spark/sql/jdbc/JDBCSuite.scala
- sql/core/src/test/scala/org/apache/spark/sql/sources/FilteredScanSuite.scala 1 addition, 1 deletion...cala/org/apache/spark/sql/sources/FilteredScanSuite.scala
- sql/core/src/test/scala/org/apache/spark/sql/sources/PrunedScanSuite.scala 1 addition, 1 deletion.../scala/org/apache/spark/sql/sources/PrunedScanSuite.scala
- sql/hive/src/test/scala/org/apache/spark/sql/hive/parquetSuites.scala 2 additions, 2 deletions.../test/scala/org/apache/spark/sql/hive/parquetSuites.scala
- sql/hive/src/test/scala/org/apache/spark/sql/sources/BucketedReadSuite.scala 2 additions, 2 deletions...cala/org/apache/spark/sql/sources/BucketedReadSuite.scala
Loading
Please register or sign in to comment