digraph G {
subgraph cluster0 {
isCluster="true";
id="cluster0";
label="WholeStageCodegen (2)\n \nduration: total (min, med, max (stageId: taskId))\n211 ms (0 ms, 13 ms, 15 ms (stage 322793.0: task 4759685))";
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>25 ms (0 ms, 0 ms, 4 ms (stage 322793.0: task 4759681))<br>peak memory total (min, med, max (stageId: taskId))<br>7.5 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 322793.0: task 4759681))<br>number of output rows: 1<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[shardId#15619034], 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#15619034, 30), ENSURE_REQUIREMENTS, [plan_id=22026599]"];
subgraph cluster3 {
isCluster="true";
id="cluster3";
label="WholeStageCodegen (1)\n \nduration: total (min, med, max (stageId: taskId))\n3.2 s (0 ms, 211 ms, 223 ms (stage 322792.0: task 4759661))";
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>39 ms (0 ms, 1 ms, 7 ms (stage 322792.0: task 4759651))<br>peak memory total (min, med, max (stageId: taskId))<br>7.5 MiB (256.0 KiB, 256.0 KiB, 256.0 KiB (stage 322792.0: task 4759654))<br>number of output rows: 1<br>number of sort fallback tasks: 0<br>avg hash probes per key: 0" tooltip="HashAggregate(keys=[shardId#15619034], functions=[])"];
}
5 [id="node5" labelType="html" label="<b>InMemoryTableScan</b><br><br>number of output rows: 4" tooltip="InMemoryTableScan [shardId#15619034]"];
6 [id="node6" 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#15619037, plant#15619038, 30), REPARTITION_BY_NUM, [plan_id=22026572]"];
subgraph cluster7 {
isCluster="true";
id="cluster7";
label="WholeStageCodegen (1)";
tooltip="WholeStageCodegen (1)";
8 [id="node8" labelType="html" label="<br><b>Scan ExistingRDD</b><br><br>" tooltip="Scan ExistingRDD[shardId#15619034,worklistShardItemId#15619035L,version#15619036,product#15619037,plant#15619038,periodStart#15619039,periodEnd#15619040,qty#15619041]"];
}
2->1;
4->2;
5->4;
6->5;
8->6;
}
== Physical Plan ==
* HashAggregate (7)
+- Exchange (6)
+- * HashAggregate (5)
+- InMemoryTableScan (1)
+- InMemoryRelation (2)
+- Exchange (4)
+- * Scan ExistingRDD (3)
(1) InMemoryTableScan
Output [1]: [shardId#15619034]
Arguments: [shardId#15619034]
(2) InMemoryRelation
Arguments: [shardId#15619034, worklistShardItemId#15619035L, version#15619036, product#15619037, plant#15619038, periodStart#15619039, periodEnd#15619040, qty#15619041], StorageLevel(disk, memory, 2 replicas)
(3) Scan ExistingRDD [codegen id : 1]
Output [8]: [shardId#15619034, worklistShardItemId#15619035L, version#15619036, product#15619037, plant#15619038, periodStart#15619039, periodEnd#15619040, qty#15619041]
Arguments: [shardId#15619034, worklistShardItemId#15619035L, version#15619036, product#15619037, plant#15619038, periodStart#15619039, periodEnd#15619040, qty#15619041], SQLExecutionRDD[903461] at start at FileStorageAdapterImpl.java:174, ExistingRDD, UnknownPartitioning(0)
(4) Exchange
Input [8]: [shardId#15619034, worklistShardItemId#15619035L, version#15619036, product#15619037, plant#15619038, periodStart#15619039, periodEnd#15619040, qty#15619041]
Arguments: hashpartitioning(product#15619037, plant#15619038, 30), REPARTITION_BY_NUM, [plan_id=22026572]
(5) HashAggregate [codegen id : 1]
Input [1]: [shardId#15619034]
Keys [1]: [shardId#15619034]
Functions: []
Aggregate Attributes: []
Results [1]: [shardId#15619034]
(6) Exchange
Input [1]: [shardId#15619034]
Arguments: hashpartitioning(shardId#15619034, 30), ENSURE_REQUIREMENTS, [plan_id=22026599]
(7) HashAggregate [codegen id : 2]
Input [1]: [shardId#15619034]
Keys [1]: [shardId#15619034]
Functions: []
Aggregate Attributes: []
Results [1]: [shardId#15619034]