digraph G {
subgraph cluster0 {
isCluster="true";
id="cluster0";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n0 ms (0 ms, 0 ms, 0 ms (stage 275908.0: task 4229066))";
tooltip="WholeStageCodegen (2)";
1 [id="node1" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>0 ms (0 ms, 0 ms, 0 ms (stage 275908.0: task 4229066))<br>peak memory total (min, med, max (stageId: taskId))<br>7.5 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 275908.0: task 4229066))<br>number of output rows: 1<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[shardId#13191126], functions=[])"];
}
2 [id="node2" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 1<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 1<br>local bytes read: 92.0 B<br>merged fetch fallback count: 0<br>local blocks read: 1<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 32.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>number of partitions: 30<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 92.0 B" tooltip="Exchange hashpartitioning(shardId#13191126, 30), ENSURE_REQUIREMENTS, [plan_id=13455067]"];
subgraph cluster3 {
isCluster="true";
id="cluster3";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n51 ms (0 ms, 0 ms, 6 ms (stage 275907.0: task 4229036))";
tooltip="WholeStageCodegen (1)";
4 [id="node4" labelType="html" label="<b>HashAggregate</b><br><br>spill size: 0.0 B<br>time in aggregation build total (min, med, max (stageId: taskId))<br>5 ms (0 ms, 0 ms, 1 ms (stage 275907.0: task 4229037))<br>peak memory total (min, med, max (stageId: taskId))<br>7.5 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 275907.0: task 4229035))<br>number of output rows: 1<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[shardId#13191126], functions=[])"];
5 [id="node5" labelType="html" label="<b>Filter</b><br><br>number of output rows: 3" tooltip="Filter isnotnull(shardId#13191126)"];
}
6 [id="node6" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 3" tooltip="InMemoryTableScan [shardId#13191126], [isnotnull(shardId#13191126)]"];
7 [id="node7" labelType="html" label="<b>Exchange</b><br><br>shuffle records written: 0<br>remote merged reqs duration: 0 ms<br>remote merged blocks fetched: 0<br>records read: 0<br>local bytes read: 0.0 B<br>merged fetch fallback count: 0<br>local blocks read: 0<br>remote merged chunks fetched: 0<br>remote blocks read: 0<br>data size: 0.0 B<br>local merged bytes read: 0.0 B<br>local merged chunks fetched: 0<br>shuffle write time: 0 ms<br>remote merged bytes read: 0.0 B<br>local merged blocks fetched: 0<br>corrupt merged block chunks: 0<br>fetch wait time: 0 ms<br>remote bytes read: 0.0 B<br>remote reqs duration: 0 ms<br>remote bytes read to disk: 0.0 B<br>shuffle bytes written: 0.0 B" tooltip="Exchange hashpartitioning(product#13191129, plant#13191130, 30), REPARTITION_BY_NUM, [plan_id=13455011]"];
subgraph cluster8 {
isCluster="true";
id="cluster8";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
9 [id="node9" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#13191126,worklistShardItemId#13191127L,version#13191128,product#13191129,plant#13191130,periodStart#13191131,periodEnd#13191132,qty#13191133]"];
}
2->1;
4->2;
5->4;
6->5;
7->6;
9->7;
}
== Physical Plan ==
* HashAggregate (8)
+- Exchange (7)
+- * HashAggregate (6)
+- * Filter (5)
+- InMemoryTableScan (1)
+- InMemoryRelation (2)
+- Exchange (4)
+- * Scan ExistingRDD (3)
(1) InMemoryTableScan
Output [1]: [shardId#13191126]
Arguments: [shardId#13191126], [isnotnull(shardId#13191126)]
(2) InMemoryRelation
Arguments: [shardId#13191126, worklistShardItemId#13191127L, version#13191128, product#13191129, plant#13191130, periodStart#13191131, periodEnd#13191132, qty#13191133], StorageLevel(disk, memory, 2 replicas)
(3) Scan ExistingRDD [codegen id : 1]
Output [8]: [shardId#13191126, worklistShardItemId#13191127L, version#13191128, product#13191129, plant#13191130, periodStart#13191131, periodEnd#13191132, qty#13191133]
Arguments: [shardId#13191126, worklistShardItemId#13191127L, version#13191128, product#13191129, plant#13191130, periodStart#13191131, periodEnd#13191132, qty#13191133], SQLExecutionRDD[781824] at start at FileStorageAdapterImpl.java:174, ExistingRDD, UnknownPartitioning(0)
(4) Exchange
Input [8]: [shardId#13191126, worklistShardItemId#13191127L, version#13191128, product#13191129, plant#13191130, periodStart#13191131, periodEnd#13191132, qty#13191133]
Arguments: hashpartitioning(product#13191129, plant#13191130, 30), REPARTITION_BY_NUM, [plan_id=13455011]
(5) Filter [codegen id : 1]
Input [1]: [shardId#13191126]
Condition : isnotnull(shardId#13191126)
(6) HashAggregate [codegen id : 1]
Input [1]: [shardId#13191126]
Keys [1]: [shardId#13191126]
Functions: []
Aggregate Attributes: []
Results [1]: [shardId#13191126]
(7) Exchange
Input [1]: [shardId#13191126]
Arguments: hashpartitioning(shardId#13191126, 30), ENSURE_REQUIREMENTS, [plan_id=13455067]
(8) HashAggregate [codegen id : 2]
Input [1]: [shardId#13191126]
Keys [1]: [shardId#13191126]
Functions: []
Aggregate Attributes: []
Results [1]: [shardId#13191126]