== Physical Plan ==
AdaptiveSparkPlan (82)
+- == Final Plan ==
* HashAggregate (78)
+- * HashAggregate (77)
+- TableCacheQueryStage (76), Statistics(sizeInBytes=423.6 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (1)
+- InMemoryRelation (2)
+- AdaptiveSparkPlan (75)
+- == Final Plan ==
* Project (72)
+- * Project (71)
+- TableCacheQueryStage (70), Statistics(sizeInBytes=383.8 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (3)
+- InMemoryRelation (4)
+- AdaptiveSparkPlan (69)
+- == Final Plan ==
* SerializeFromObject (65)
+- MapPartitions (64)
+- DeserializeToObject (63)
+- TableCacheQueryStage (62), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (5)
+- InMemoryRelation (6)
+- AdaptiveSparkPlan (61)
+- == Final Plan ==
ShuffleQueryStage (59), Statistics(sizeInBytes=434.4 KiB, rowCount=1.20E+3)
+- Exchange (58)
+- TableCacheQueryStage (57), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
Exchange (60)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
SerializeFromObject (68)
+- MapPartitions (67)
+- DeserializeToObject (66)
+- InMemoryTableScan (5)
+- InMemoryRelation (6)
+- AdaptiveSparkPlan (61)
+- == Final Plan ==
ShuffleQueryStage (59), Statistics(sizeInBytes=434.4 KiB, rowCount=1.20E+3)
+- Exchange (58)
+- TableCacheQueryStage (57), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
Exchange (60)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
Project (74)
+- Project (73)
+- InMemoryTableScan (3)
+- InMemoryRelation (4)
+- AdaptiveSparkPlan (69)
+- == Final Plan ==
* SerializeFromObject (65)
+- MapPartitions (64)
+- DeserializeToObject (63)
+- TableCacheQueryStage (62), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (5)
+- InMemoryRelation (6)
+- AdaptiveSparkPlan (61)
+- == Final Plan ==
ShuffleQueryStage (59), Statistics(sizeInBytes=434.4 KiB, rowCount=1.20E+3)
+- Exchange (58)
+- TableCacheQueryStage (57), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
Exchange (60)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
SerializeFromObject (68)
+- MapPartitions (67)
+- DeserializeToObject (66)
+- InMemoryTableScan (5)
+- InMemoryRelation (6)
+- AdaptiveSparkPlan (61)
+- == Final Plan ==
ShuffleQueryStage (59), Statistics(sizeInBytes=434.4 KiB, rowCount=1.20E+3)
+- Exchange (58)
+- TableCacheQueryStage (57), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
Exchange (60)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
HashAggregate (81)
+- Exchange (80)
+- HashAggregate (79)
+- InMemoryTableScan (1)
+- InMemoryRelation (2)
+- AdaptiveSparkPlan (75)
+- == Final Plan ==
* Project (72)
+- * Project (71)
+- TableCacheQueryStage (70), Statistics(sizeInBytes=383.8 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (3)
+- InMemoryRelation (4)
+- AdaptiveSparkPlan (69)
+- == Final Plan ==
* SerializeFromObject (65)
+- MapPartitions (64)
+- DeserializeToObject (63)
+- TableCacheQueryStage (62), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (5)
+- InMemoryRelation (6)
+- AdaptiveSparkPlan (61)
+- == Final Plan ==
ShuffleQueryStage (59), Statistics(sizeInBytes=434.4 KiB, rowCount=1.20E+3)
+- Exchange (58)
+- TableCacheQueryStage (57), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
Exchange (60)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
SerializeFromObject (68)
+- MapPartitions (67)
+- DeserializeToObject (66)
+- InMemoryTableScan (5)
+- InMemoryRelation (6)
+- AdaptiveSparkPlan (61)
+- == Final Plan ==
ShuffleQueryStage (59), Statistics(sizeInBytes=434.4 KiB, rowCount=1.20E+3)
+- Exchange (58)
+- TableCacheQueryStage (57), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
Exchange (60)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
Project (74)
+- Project (73)
+- InMemoryTableScan (3)
+- InMemoryRelation (4)
+- AdaptiveSparkPlan (69)
+- == Final Plan ==
* SerializeFromObject (65)
+- MapPartitions (64)
+- DeserializeToObject (63)
+- TableCacheQueryStage (62), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (5)
+- InMemoryRelation (6)
+- AdaptiveSparkPlan (61)
+- == Final Plan ==
ShuffleQueryStage (59), Statistics(sizeInBytes=434.4 KiB, rowCount=1.20E+3)
+- Exchange (58)
+- TableCacheQueryStage (57), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
Exchange (60)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
SerializeFromObject (68)
+- MapPartitions (67)
+- DeserializeToObject (66)
+- InMemoryTableScan (5)
+- InMemoryRelation (6)
+- AdaptiveSparkPlan (61)
+- == Final Plan ==
ShuffleQueryStage (59), Statistics(sizeInBytes=434.4 KiB, rowCount=1.20E+3)
+- Exchange (58)
+- TableCacheQueryStage (57), Statistics(sizeInBytes=379.1 KiB, rowCount=1.20E+3)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
+- == Initial Plan ==
Exchange (60)
+- InMemoryTableScan (7)
+- InMemoryRelation (8)
+- AdaptiveSparkPlan (56)
+- == Final Plan ==
* Project (38)
+- * Generate (37)
+- * Project (36)
+- * Project (35)
+- * BroadcastHashJoin LeftOuter BuildRight (34)
:- ShuffleQueryStage (15), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (14)
: +- ShuffleQueryStage (13), Statistics(sizeInBytes=304.9 KiB, rowCount=179)
: +- Exchange (12)
: +- * Filter (11)
: +- * ColumnarToRow (10)
: +- Scan parquet (9)
+- BroadcastQueryStage (33), Statistics(sizeInBytes=2.0 MiB, rowCount=179)
+- BroadcastExchange (32)
+- AQEShuffleRead (31)
+- ShuffleQueryStage (30), Statistics(sizeInBytes=58.3 KiB, rowCount=179)
+- Exchange (29)
+- * Project (28)
+- * BroadcastHashJoin LeftOuter BuildRight (27)
:- ShuffleQueryStage (19), Statistics(sizeInBytes=28.9 KiB, rowCount=179)
: +- Exchange (18)
: +- * ColumnarToRow (17)
: +- Scan parquet (16)
+- BroadcastQueryStage (26), Statistics(sizeInBytes=2.0 MiB, rowCount=1)
+- BroadcastExchange (25)
+- ShuffleQueryStage (24), Statistics(sizeInBytes=208.0 B, rowCount=1)
+- Exchange (23)
+- * Filter (22)
+- * ColumnarToRow (21)
+- Scan parquet (20)
+- == Initial Plan ==
Project (55)
+- Generate (54)
+- Project (53)
+- Project (52)
+- SortMergeJoin LeftOuter (51)
:- Sort (42)
: +- Exchange (41)
: +- Exchange (40)
: +- Filter (39)
: +- Scan parquet (9)
+- Sort (50)
+- Exchange (49)
+- Project (48)
+- BroadcastHashJoin LeftOuter BuildRight (47)
:- Exchange (43)
: +- Scan parquet (16)
+- BroadcastExchange (46)
+- Exchange (45)
+- Filter (44)
+- Scan parquet (20)
(1) InMemoryTableScan
Output [1]: [shardId#6186]
Arguments: [shardId#6186]
(2) InMemoryRelation
Arguments: [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, shardId#6186, worklistShardItemId#6222L, orderProposalItemGroupId#6241, orderProposalItemId#6261], CachedRDDBuilder(org.apache.spark.sql.execution.columnar.DefaultCachedBatchSerializer@763c116,StorageLevel(disk, memory, 2 replicas),AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(1) Project [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, shardId#6186, worklistShardItemId#6222L, null AS orderProposalItemGroupId#6241, cast((monotonically_increasing_id() % 9999999999) as string) AS orderProposalItemId#6261]
+- *(1) Project [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, concat(0, _, cast(binId#5860 as string), _, 10000000095) AS shardId#6186, monotonically_increasing_id() AS worklistShardItemId#6222L]
+- TableCacheQueryStage 0
+- InMemoryTableScan [availabilityDateTime#5851, binId#5860, deliveryDateTime#5847, mrpController#5853, nextAvailabilityDateTime#5852, orderDateTime#5850, orderProposalHorizonGroupingId#5858L, orderProposalId#5857L, plant#5846, product#5849, purchasingGroup#5856, purchasingOrg#5855, sourceOfSupplyUuid#5854, splitIndicator#5859L, subrange#5848, supplier#5845, supplierGroup#5844]
+- InMemoryRelation [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, binId#5860], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(1) SerializeFromObject [if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 0, supplierGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplierGroup#5844, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 1, supplier), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplier#5845, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 2, plant), StringType, ObjectType(class java.lang.String)), true, false, true) AS plant#5846, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 3, deliveryDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS deliveryDateTime#5847, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 4, subrange), StringType, ObjectType(class java.lang.String)), true, false, true) AS subrange#5848, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 5, product), StringType, ObjectType(class java.lang.String)), true, false, true) AS product#5849, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 6, orderDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS orderDateTime#5850, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 7, availabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS availabilityDateTime#5851, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 8, nextAvailabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS nextAvailabilityDateTime#5852, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 9, mrpController), StringType, ObjectType(class java.lang.String)), true, false, true) AS mrpController#5853, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 10, sourceOfSupplyUuid), StringType, ObjectType(class java.lang.String)), true, false, true) AS sourceOfSupplyUuid#5854, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 11, purchasingOrg), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingOrg#5855, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 12, purchasingGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingGroup#5856, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 13, orderProposalId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalId#5857L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 14, orderProposalHorizonGroupingId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalHorizonGroupingId#5858L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 15, splitIndicator), LongType, ObjectType(class java.lang.Long)).longValue) AS splitIndicator#5859L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 16, binId), IntegerType, ObjectType(class java.lang.Integer)).intValue) AS binId#5860]
+- MapPartitions org.apache.spark.sql.Dataset$$Lambda$7144/0x00007f71e9afe200@60ecfd47, obj#5843: org.apache.spark.sql.Row
+- DeserializeToObject createexternalrow(supplierGroup#2999.toString, supplier#3000.toString, plant#3001.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, deliveryDateTime#3002, true, false, true), subrange#3003.toString, product#3315.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, orderDateTime#3316, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, availabilityDateTime#3317, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, nextAvailabilityDateTime#3318, true, false, true), mrpController#3319.toString, sourceOfSupplyUuid#3320.toString, purchasingOrg#3321.toString, purchasingGroup#3322.toString, staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalId#3715L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalHorizonGroupingId#3736L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, splitIndicator#4136L, true, false, true), StructField(supplierGroup,StringType,true), StructField(supplier,StringType,true), StructField(plant,StringType,true), StructField(deliveryDateTime,TimestampType,true), StructField(subrange,StringType,true), StructField(product,StringType,true), StructField(orderDateTime,TimestampType,true), StructField(availabilityDateTime,TimestampType,true), ... 8 more fields), obj#5842: org.apache.spark.sql.Row
+- TableCacheQueryStage 0
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
ShuffleQueryStage 1
+- Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2268]
+- TableCacheQueryStage 0
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2208]
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
SerializeFromObject [if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 0, supplierGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplierGroup#5844, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 1, supplier), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplier#5845, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 2, plant), StringType, ObjectType(class java.lang.String)), true, false, true) AS plant#5846, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 3, deliveryDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS deliveryDateTime#5847, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 4, subrange), StringType, ObjectType(class java.lang.String)), true, false, true) AS subrange#5848, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 5, product), StringType, ObjectType(class java.lang.String)), true, false, true) AS product#5849, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 6, orderDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS orderDateTime#5850, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 7, availabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS availabilityDateTime#5851, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 8, nextAvailabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS nextAvailabilityDateTime#5852, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 9, mrpController), StringType, ObjectType(class java.lang.String)), true, false, true) AS mrpController#5853, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 10, sourceOfSupplyUuid), StringType, ObjectType(class java.lang.String)), true, false, true) AS sourceOfSupplyUuid#5854, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 11, purchasingOrg), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingOrg#5855, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 12, purchasingGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingGroup#5856, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 13, orderProposalId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalId#5857L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 14, orderProposalHorizonGroupingId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalHorizonGroupingId#5858L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 15, splitIndicator), LongType, ObjectType(class java.lang.Long)).longValue) AS splitIndicator#5859L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 16, binId), IntegerType, ObjectType(class java.lang.Integer)).intValue) AS binId#5860]
+- MapPartitions org.apache.spark.sql.Dataset$$Lambda$7144/0x00007f71e9afe200@60ecfd47, obj#5843: org.apache.spark.sql.Row
+- DeserializeToObject createexternalrow(supplierGroup#2999.toString, supplier#3000.toString, plant#3001.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, deliveryDateTime#3002, true, false, true), subrange#3003.toString, product#3315.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, orderDateTime#3316, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, availabilityDateTime#3317, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, nextAvailabilityDateTime#3318, true, false, true), mrpController#3319.toString, sourceOfSupplyUuid#3320.toString, purchasingOrg#3321.toString, purchasingGroup#3322.toString, staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalId#3715L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalHorizonGroupingId#3736L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, splitIndicator#4136L, true, false, true), StructField(supplierGroup,StringType,true), StructField(supplier,StringType,true), StructField(plant,StringType,true), StructField(deliveryDateTime,TimestampType,true), StructField(subrange,StringType,true), StructField(product,StringType,true), StructField(orderDateTime,TimestampType,true), StructField(availabilityDateTime,TimestampType,true), ... 8 more fields), obj#5842: org.apache.spark.sql.Row
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
ShuffleQueryStage 1
+- Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2268]
+- TableCacheQueryStage 0
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2208]
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, shardId#6186, worklistShardItemId#6222L, null AS orderProposalItemGroupId#6241, cast((monotonically_increasing_id() % 9999999999) as string) AS orderProposalItemId#6261]
+- Project [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, concat(0, _, cast(binId#5860 as string), _, 10000000095) AS shardId#6186, monotonically_increasing_id() AS worklistShardItemId#6222L]
+- InMemoryTableScan [availabilityDateTime#5851, binId#5860, deliveryDateTime#5847, mrpController#5853, nextAvailabilityDateTime#5852, orderDateTime#5850, orderProposalHorizonGroupingId#5858L, orderProposalId#5857L, plant#5846, product#5849, purchasingGroup#5856, purchasingOrg#5855, sourceOfSupplyUuid#5854, splitIndicator#5859L, subrange#5848, supplier#5845, supplierGroup#5844]
+- InMemoryRelation [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, binId#5860], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(1) SerializeFromObject [if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 0, supplierGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplierGroup#5844, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 1, supplier), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplier#5845, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 2, plant), StringType, ObjectType(class java.lang.String)), true, false, true) AS plant#5846, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 3, deliveryDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS deliveryDateTime#5847, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 4, subrange), StringType, ObjectType(class java.lang.String)), true, false, true) AS subrange#5848, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 5, product), StringType, ObjectType(class java.lang.String)), true, false, true) AS product#5849, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 6, orderDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS orderDateTime#5850, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 7, availabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS availabilityDateTime#5851, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 8, nextAvailabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS nextAvailabilityDateTime#5852, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 9, mrpController), StringType, ObjectType(class java.lang.String)), true, false, true) AS mrpController#5853, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 10, sourceOfSupplyUuid), StringType, ObjectType(class java.lang.String)), true, false, true) AS sourceOfSupplyUuid#5854, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 11, purchasingOrg), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingOrg#5855, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 12, purchasingGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingGroup#5856, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 13, orderProposalId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalId#5857L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 14, orderProposalHorizonGroupingId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalHorizonGroupingId#5858L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 15, splitIndicator), LongType, ObjectType(class java.lang.Long)).longValue) AS splitIndicator#5859L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 16, binId), IntegerType, ObjectType(class java.lang.Integer)).intValue) AS binId#5860]
+- MapPartitions org.apache.spark.sql.Dataset$$Lambda$7144/0x00007f71e9afe200@60ecfd47, obj#5843: org.apache.spark.sql.Row
+- DeserializeToObject createexternalrow(supplierGroup#2999.toString, supplier#3000.toString, plant#3001.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, deliveryDateTime#3002, true, false, true), subrange#3003.toString, product#3315.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, orderDateTime#3316, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, availabilityDateTime#3317, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, nextAvailabilityDateTime#3318, true, false, true), mrpController#3319.toString, sourceOfSupplyUuid#3320.toString, purchasingOrg#3321.toString, purchasingGroup#3322.toString, staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalId#3715L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalHorizonGroupingId#3736L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, splitIndicator#4136L, true, false, true), StructField(supplierGroup,StringType,true), StructField(supplier,StringType,true), StructField(plant,StringType,true), StructField(deliveryDateTime,TimestampType,true), StructField(subrange,StringType,true), StructField(product,StringType,true), StructField(orderDateTime,TimestampType,true), StructField(availabilityDateTime,TimestampType,true), ... 8 more fields), obj#5842: org.apache.spark.sql.Row
+- TableCacheQueryStage 0
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
ShuffleQueryStage 1
+- Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2268]
+- TableCacheQueryStage 0
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2208]
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
SerializeFromObject [if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 0, supplierGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplierGroup#5844, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 1, supplier), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplier#5845, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 2, plant), StringType, ObjectType(class java.lang.String)), true, false, true) AS plant#5846, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 3, deliveryDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS deliveryDateTime#5847, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 4, subrange), StringType, ObjectType(class java.lang.String)), true, false, true) AS subrange#5848, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 5, product), StringType, ObjectType(class java.lang.String)), true, false, true) AS product#5849, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 6, orderDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS orderDateTime#5850, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 7, availabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS availabilityDateTime#5851, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 8, nextAvailabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS nextAvailabilityDateTime#5852, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 9, mrpController), StringType, ObjectType(class java.lang.String)), true, false, true) AS mrpController#5853, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 10, sourceOfSupplyUuid), StringType, ObjectType(class java.lang.String)), true, false, true) AS sourceOfSupplyUuid#5854, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 11, purchasingOrg), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingOrg#5855, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 12, purchasingGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingGroup#5856, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 13, orderProposalId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalId#5857L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 14, orderProposalHorizonGroupingId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalHorizonGroupingId#5858L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 15, splitIndicator), LongType, ObjectType(class java.lang.Long)).longValue) AS splitIndicator#5859L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 16, binId), IntegerType, ObjectType(class java.lang.Integer)).intValue) AS binId#5860]
+- MapPartitions org.apache.spark.sql.Dataset$$Lambda$7144/0x00007f71e9afe200@60ecfd47, obj#5843: org.apache.spark.sql.Row
+- DeserializeToObject createexternalrow(supplierGroup#2999.toString, supplier#3000.toString, plant#3001.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, deliveryDateTime#3002, true, false, true), subrange#3003.toString, product#3315.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, orderDateTime#3316, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, availabilityDateTime#3317, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, nextAvailabilityDateTime#3318, true, false, true), mrpController#3319.toString, sourceOfSupplyUuid#3320.toString, purchasingOrg#3321.toString, purchasingGroup#3322.toString, staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalId#3715L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalHorizonGroupingId#3736L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, splitIndicator#4136L, true, false, true), StructField(supplierGroup,StringType,true), StructField(supplier,StringType,true), StructField(plant,StringType,true), StructField(deliveryDateTime,TimestampType,true), StructField(subrange,StringType,true), StructField(product,StringType,true), StructField(orderDateTime,TimestampType,true), StructField(availabilityDateTime,TimestampType,true), ... 8 more fields), obj#5842: org.apache.spark.sql.Row
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
ShuffleQueryStage 1
+- Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2268]
+- TableCacheQueryStage 0
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2208]
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
,None)
(3) InMemoryTableScan
Output [17]: [availabilityDateTime#5851, binId#5860, deliveryDateTime#5847, mrpController#5853, nextAvailabilityDateTime#5852, orderDateTime#5850, orderProposalHorizonGroupingId#5858L, orderProposalId#5857L, plant#5846, product#5849, purchasingGroup#5856, purchasingOrg#5855, sourceOfSupplyUuid#5854, splitIndicator#5859L, subrange#5848, supplier#5845, supplierGroup#5844]
Arguments: [availabilityDateTime#5851, binId#5860, deliveryDateTime#5847, mrpController#5853, nextAvailabilityDateTime#5852, orderDateTime#5850, orderProposalHorizonGroupingId#5858L, orderProposalId#5857L, plant#5846, product#5849, purchasingGroup#5856, purchasingOrg#5855, sourceOfSupplyUuid#5854, splitIndicator#5859L, subrange#5848, supplier#5845, supplierGroup#5844]
(4) InMemoryRelation
Arguments: [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, binId#5860], CachedRDDBuilder(org.apache.spark.sql.execution.columnar.DefaultCachedBatchSerializer@763c116,StorageLevel(disk, memory, 2 replicas),AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(1) SerializeFromObject [if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 0, supplierGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplierGroup#5844, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 1, supplier), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplier#5845, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 2, plant), StringType, ObjectType(class java.lang.String)), true, false, true) AS plant#5846, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 3, deliveryDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS deliveryDateTime#5847, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 4, subrange), StringType, ObjectType(class java.lang.String)), true, false, true) AS subrange#5848, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 5, product), StringType, ObjectType(class java.lang.String)), true, false, true) AS product#5849, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 6, orderDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS orderDateTime#5850, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 7, availabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS availabilityDateTime#5851, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 8, nextAvailabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS nextAvailabilityDateTime#5852, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 9, mrpController), StringType, ObjectType(class java.lang.String)), true, false, true) AS mrpController#5853, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 10, sourceOfSupplyUuid), StringType, ObjectType(class java.lang.String)), true, false, true) AS sourceOfSupplyUuid#5854, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 11, purchasingOrg), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingOrg#5855, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 12, purchasingGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingGroup#5856, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 13, orderProposalId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalId#5857L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 14, orderProposalHorizonGroupingId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalHorizonGroupingId#5858L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 15, splitIndicator), LongType, ObjectType(class java.lang.Long)).longValue) AS splitIndicator#5859L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 16, binId), IntegerType, ObjectType(class java.lang.Integer)).intValue) AS binId#5860]
+- MapPartitions org.apache.spark.sql.Dataset$$Lambda$7144/0x00007f71e9afe200@60ecfd47, obj#5843: org.apache.spark.sql.Row
+- DeserializeToObject createexternalrow(supplierGroup#2999.toString, supplier#3000.toString, plant#3001.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, deliveryDateTime#3002, true, false, true), subrange#3003.toString, product#3315.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, orderDateTime#3316, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, availabilityDateTime#3317, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, nextAvailabilityDateTime#3318, true, false, true), mrpController#3319.toString, sourceOfSupplyUuid#3320.toString, purchasingOrg#3321.toString, purchasingGroup#3322.toString, staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalId#3715L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalHorizonGroupingId#3736L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, splitIndicator#4136L, true, false, true), StructField(supplierGroup,StringType,true), StructField(supplier,StringType,true), StructField(plant,StringType,true), StructField(deliveryDateTime,TimestampType,true), StructField(subrange,StringType,true), StructField(product,StringType,true), StructField(orderDateTime,TimestampType,true), StructField(availabilityDateTime,TimestampType,true), ... 8 more fields), obj#5842: org.apache.spark.sql.Row
+- TableCacheQueryStage 0
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
ShuffleQueryStage 1
+- Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2268]
+- TableCacheQueryStage 0
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2208]
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
SerializeFromObject [if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 0, supplierGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplierGroup#5844, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 1, supplier), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplier#5845, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 2, plant), StringType, ObjectType(class java.lang.String)), true, false, true) AS plant#5846, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 3, deliveryDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS deliveryDateTime#5847, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 4, subrange), StringType, ObjectType(class java.lang.String)), true, false, true) AS subrange#5848, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 5, product), StringType, ObjectType(class java.lang.String)), true, false, true) AS product#5849, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 6, orderDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS orderDateTime#5850, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 7, availabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS availabilityDateTime#5851, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 8, nextAvailabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS nextAvailabilityDateTime#5852, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 9, mrpController), StringType, ObjectType(class java.lang.String)), true, false, true) AS mrpController#5853, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 10, sourceOfSupplyUuid), StringType, ObjectType(class java.lang.String)), true, false, true) AS sourceOfSupplyUuid#5854, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 11, purchasingOrg), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingOrg#5855, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 12, purchasingGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingGroup#5856, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 13, orderProposalId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalId#5857L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 14, orderProposalHorizonGroupingId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalHorizonGroupingId#5858L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 15, splitIndicator), LongType, ObjectType(class java.lang.Long)).longValue) AS splitIndicator#5859L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 16, binId), IntegerType, ObjectType(class java.lang.Integer)).intValue) AS binId#5860]
+- MapPartitions org.apache.spark.sql.Dataset$$Lambda$7144/0x00007f71e9afe200@60ecfd47, obj#5843: org.apache.spark.sql.Row
+- DeserializeToObject createexternalrow(supplierGroup#2999.toString, supplier#3000.toString, plant#3001.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, deliveryDateTime#3002, true, false, true), subrange#3003.toString, product#3315.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, orderDateTime#3316, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, availabilityDateTime#3317, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, nextAvailabilityDateTime#3318, true, false, true), mrpController#3319.toString, sourceOfSupplyUuid#3320.toString, purchasingOrg#3321.toString, purchasingGroup#3322.toString, staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalId#3715L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalHorizonGroupingId#3736L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, splitIndicator#4136L, true, false, true), StructField(supplierGroup,StringType,true), StructField(supplier,StringType,true), StructField(plant,StringType,true), StructField(deliveryDateTime,TimestampType,true), StructField(subrange,StringType,true), StructField(product,StringType,true), StructField(orderDateTime,TimestampType,true), StructField(availabilityDateTime,TimestampType,true), ... 8 more fields), obj#5842: org.apache.spark.sql.Row
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
ShuffleQueryStage 1
+- Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2268]
+- TableCacheQueryStage 0
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2208]
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
,None)
(5) InMemoryTableScan
Output [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
(6) InMemoryRelation
Arguments: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], CachedRDDBuilder(org.apache.spark.sql.execution.columnar.DefaultCachedBatchSerializer@763c116,StorageLevel(disk, memory, 2 replicas),AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
ShuffleQueryStage 1
+- Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2268]
+- TableCacheQueryStage 0
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Exchange SinglePartition, REPARTITION_BY_NUM, [plan_id=2208]
+- InMemoryTableScan [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
+- InMemoryRelation [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], StorageLevel(disk, memory, 2 replicas)
+- AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
,None)
(7) InMemoryTableScan
Output [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
(8) InMemoryRelation
Arguments: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L], CachedRDDBuilder(org.apache.spark.sql.execution.columnar.DefaultCachedBatchSerializer@763c116,StorageLevel(disk, memory, 2 replicas),AdaptiveSparkPlan isFinalPlan=true
+- == Final Plan ==
*(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- *(5) Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- *(5) Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- *(5) BroadcastHashJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter, BuildRight, false
:- ShuffleQueryStage 4
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
: +- ShuffleQueryStage 0
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
: +- *(1) Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- *(1) ColumnarToRow
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- BroadcastQueryStage 6
+- BroadcastExchange HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
+- AQEShuffleRead local
+- ShuffleQueryStage 5
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
+- *(4) Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- *(4) BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- ShuffleQueryStage 1
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
: +- *(2) ColumnarToRow
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastQueryStage 3
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
+- ShuffleQueryStage 2
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
+- *(3) Filter isnotnull(orderGroupingProfile#3109)
+- *(3) ColumnarToRow
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
+- == Initial Plan ==
Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
+- Generate explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
+- Project [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
+- SortMergeJoin [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)], [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)], LeftOuter
:- Sort [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
: +- Exchange hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
: +- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
: +- Filter ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
: +- FileScan parquet [supplierGroup#2999,supplier#3000,plant#3001,deliveryDateTime#3002,subrange#3003,productOrderSchedule#3004] Batched: true, DataFilters: [(size(productOrderSchedule#3004, true) > 0), isnotnull(productOrderSchedule#3004)], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [IsNotNull(productOrderSchedule)], ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:stri...
+- Sort [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
+- Exchange hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
+- Project [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
+- BroadcastHashJoin [orderGroupingProfile#3015], [orderGroupingProfile#3109], LeftOuter, BuildRight, false
:- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
: +- FileScan parquet [supplier#3011,subrange#3012,plant#3013,deliverydatetime#3014,ordergroupingprofile#3015,supplierGroup#3016,locationGroup#3017] Batched: true, DataFilters: [], Format: Parquet, Location: InMemoryFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanac..., PartitionFilters: [], PushedFilters: [], ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofi...
+- BroadcastExchange HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
+- Exchange RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
+- Filter isnotnull(orderGroupingProfile#3109)
+- FileScan parquet [orderGroupingProfile#3109,orderGroupCriteria#3111,orderSplitCriteria#3112] Batched: true, DataFilters: [isnotnull(orderGroupingProfile#3109)], Format: Parquet, Location: PreparedDeltaFileIndex(1 paths)[hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20...., PartitionFilters: [], PushedFilters: [IsNotNull(orderGroupingProfile)], ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:bo...
,None)
(9) Scan parquet
Output [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
Batched: true
Location: InMemoryFileIndex [hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanacloud.ondemand.com:443/crp-order-qty-opt-service/out/grouping-worklist/10000000095]
PushedFilters: [IsNotNull(productOrderSchedule)]
ReadSchema: struct<supplierGroup:string,supplier:string,plant:string,deliveryDateTime:timestamp,subrange:string,productOrderSchedule:array<struct<product:string,orderDateTime:timestamp,availabilityDateTime:timestamp,nextAvailabilityDateTime:timestamp,mrpController:string,sourceOfSupplyUuid:string,purchasingOrg:string,purchasingGroup:string>>>
(10) ColumnarToRow [codegen id : 1]
Input [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
(11) Filter [codegen id : 1]
Input [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
Condition : ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
(12) Exchange
Input [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
Arguments: RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1708]
(13) ShuffleQueryStage
Output [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
Arguments: 0
(14) Exchange
Input [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
Arguments: hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1716]
(15) ShuffleQueryStage
Output [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
Arguments: 4
(16) Scan parquet
Output [7]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017]
Batched: true
Location: InMemoryFileIndex [hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanacloud.ondemand.com:443/crp-param-determination-service/out/10000000095]
ReadSchema: struct<supplier:string,subrange:string,plant:string,deliverydatetime:timestamp,ordergroupingprofile:string,supplierGroup:string,locationGroup:string>
(17) ColumnarToRow [codegen id : 2]
Input [7]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017]
(18) Exchange
Input [7]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017]
Arguments: RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1736]
(19) ShuffleQueryStage
Output [7]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017]
Arguments: 1
(20) Scan parquet
Output [3]: [orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
Batched: true
Location: PreparedDeltaFileIndex [hdlfs://2e93940d-4be8-4f12-830d-f0b8d392c03a.files.hdl.prod-eu20.hanacloud.ondemand.com:443/crp-dl-stream-service/prp/order-grouping-profile]
PushedFilters: [IsNotNull(orderGroupingProfile)]
ReadSchema: struct<orderGroupingProfile:string,orderGroupCriteria:struct<supplier:boolean,supplierSubrange:boolean,receivingLocation:boolean,deliveryDate:boolean,orderDate:boolean,purchasingOrg:boolean,purchasingGroup:boolean,mrpController:boolean>,orderSplitCriteria:struct<supplier:boolean,supplierSubrange:boolean,receivingLocation:boolean,deliveryDate:boolean,multiplesOrderQuantity:boolean,orderDate:boolean,purchasingOrg:boolean,purchasingGroup:boolean,mrpController:boolean>>
(21) ColumnarToRow [codegen id : 3]
Input [3]: [orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
(22) Filter [codegen id : 3]
Input [3]: [orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
Condition : isnotnull(orderGroupingProfile#3109)
(23) Exchange
Input [3]: [orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1749]
(24) ShuffleQueryStage
Output [3]: [orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: 2
(25) BroadcastExchange
Input [3]: [orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1757]
(26) BroadcastQueryStage
Output [3]: [orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: 3
(27) BroadcastHashJoin [codegen id : 4]
Left keys [1]: [orderGroupingProfile#3015]
Right keys [1]: [orderGroupingProfile#3109]
Join type: LeftOuter
Join condition: None
(28) Project [codegen id : 4]
Output [9]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
Input [10]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
(29) Exchange
Input [9]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1955]
(30) ShuffleQueryStage
Output [9]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: 5
(31) AQEShuffleRead
Input [9]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: local
(32) BroadcastExchange
Input [9]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: HashedRelationBroadcastMode(List(coalesce(input[5, string, true], ), isnull(input[5, string, true]), coalesce(input[0, string, true], ), isnull(input[0, string, true]), coalesce(input[1, string, true], ), isnull(input[1, string, true]), coalesce(input[2, string, true], ), isnull(input[2, string, true]), coalesce(input[3, timestamp, true], 1970-01-01 00:00:00), isnull(input[3, timestamp, true])),false), [plan_id=2025]
(33) BroadcastQueryStage
Output [9]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: 6
(34) BroadcastHashJoin [codegen id : 5]
Left keys [10]: [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)]
Right keys [10]: [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)]
Join type: LeftOuter
Join condition: None
(35) Project [codegen id : 5]
Output [11]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
Input [15]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
(36) Project [codegen id : 5]
Output [23]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
Input [11]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265, orderSplitCriteria#3287, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
(37) Generate [codegen id : 5]
Input [23]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
Arguments: explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
(38) Project [codegen id : 5]
Output [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
Input [23]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220, productOrderScheduleExploded#3301]
(39) Filter
Input [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
Condition : ((size(productOrderSchedule#3004, true) > 0) AND isnotnull(productOrderSchedule#3004))
(40) Exchange
Input [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
Arguments: RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1651]
(41) Exchange
Input [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
Arguments: hashpartitioning(coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002), 25), ENSURE_REQUIREMENTS, [plan_id=1665]
(42) Sort
Input [6]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004]
Arguments: [coalesce(supplierGroup#2999, ) ASC NULLS FIRST, isnull(supplierGroup#2999) ASC NULLS FIRST, coalesce(supplier#3000, ) ASC NULLS FIRST, isnull(supplier#3000) ASC NULLS FIRST, coalesce(subrange#3003, ) ASC NULLS FIRST, isnull(subrange#3003) ASC NULLS FIRST, coalesce(plant#3001, ) ASC NULLS FIRST, isnull(plant#3001) ASC NULLS FIRST, coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3002) ASC NULLS FIRST], false, 0
(43) Exchange
Input [7]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017]
Arguments: RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1638]
(44) Filter
Input [3]: [orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
Condition : isnotnull(orderGroupingProfile#3109)
(45) Exchange
Input [3]: [orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: RoundRobinPartitioning(25), REPARTITION_BY_NUM, [plan_id=1652]
(46) BroadcastExchange
Input [3]: [orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: HashedRelationBroadcastMode(List(input[0, string, false]),false), [plan_id=1660]
(47) BroadcastHashJoin
Left keys [1]: [orderGroupingProfile#3015]
Right keys [1]: [orderGroupingProfile#3109]
Join type: LeftOuter
Join condition: None
(48) Project
Output [9]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
Input [10]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupingProfile#3109, orderGroupCriteria#3111, orderSplitCriteria#3112]
(49) Exchange
Input [9]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: hashpartitioning(coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014), 25), ENSURE_REQUIREMENTS, [plan_id=1666]
(50) Sort
Input [9]: [supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
Arguments: [coalesce(supplierGroup#3016, ) ASC NULLS FIRST, isnull(supplierGroup#3016) ASC NULLS FIRST, coalesce(supplier#3011, ) ASC NULLS FIRST, isnull(supplier#3011) ASC NULLS FIRST, coalesce(subrange#3012, ) ASC NULLS FIRST, isnull(subrange#3012) ASC NULLS FIRST, coalesce(plant#3013, ) ASC NULLS FIRST, isnull(plant#3013) ASC NULLS FIRST, coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00) ASC NULLS FIRST, isnull(deliveryDateTime#3014) ASC NULLS FIRST], false, 0
(51) SortMergeJoin
Left keys [10]: [coalesce(supplierGroup#2999, ), isnull(supplierGroup#2999), coalesce(supplier#3000, ), isnull(supplier#3000), coalesce(subrange#3003, ), isnull(subrange#3003), coalesce(plant#3001, ), isnull(plant#3001), coalesce(deliveryDateTime#3002, 1970-01-01 00:00:00), isnull(deliveryDateTime#3002)]
Right keys [10]: [coalesce(supplierGroup#3016, ), isnull(supplierGroup#3016), coalesce(supplier#3011, ), isnull(supplier#3011), coalesce(subrange#3012, ), isnull(subrange#3012), coalesce(plant#3013, ), isnull(plant#3013), coalesce(deliveryDateTime#3014, 1970-01-01 00:00:00), isnull(deliveryDateTime#3014)]
Join type: LeftOuter
Join condition: None
(52) Project
Output [11]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, CASE WHEN isnull(orderGroupCriteria#3111) THEN [true,false,false,false,true,false,false,false] ELSE orderGroupCriteria#3111 END AS orderGroupCriteria#3265, CASE WHEN isnull(orderSplitCriteria#3112) THEN [true,false,false,false,false,true,false,false,false] ELSE orderSplitCriteria#3112 END AS orderSplitCriteria#3287, orderGroupingProfile#3015, coalesce(supplierGroup#2999, supplier#3000) AS supplierOrGroup#3208, coalesce(locationGroup#3017, plant#3001) AS locationOrGroup#3220]
Input [15]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, supplier#3011, subrange#3012, plant#3013, deliverydatetime#3014, ordergroupingprofile#3015, supplierGroup#3016, locationGroup#3017, orderGroupCriteria#3111, orderSplitCriteria#3112]
(53) Project
Output [23]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265.supplier AS _extract_supplier#4175, orderGroupCriteria#3265.deliveryDate AS _extract_deliveryDate#4176, orderGroupCriteria#3265.orderDate AS _extract_orderDate#4177, orderGroupCriteria#3265.supplierSubrange AS _extract_supplierSubrange#4178, orderGroupCriteria#3265.purchasingOrg AS _extract_purchasingOrg#4179, orderGroupCriteria#3265.mrpController AS _extract_mrpController#4180, orderGroupCriteria#3265.purchasingGroup AS _extract_purchasingGroup#4181, orderSplitCriteria#3287.purchasingOrg AS _extract_purchasingOrg#4182, orderSplitCriteria#3287.deliveryDate AS _extract_deliveryDate#4183, orderSplitCriteria#3287.supplier AS _extract_supplier#4184, orderSplitCriteria#3287.supplierSubrange AS _extract_supplierSubrange#4185, orderSplitCriteria#3287.orderDate AS _extract_orderDate#4186, orderSplitCriteria#3287.mrpController AS _extract_mrpController#4187, orderSplitCriteria#3287.purchasingGroup AS _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
Input [11]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, orderGroupCriteria#3265, orderSplitCriteria#3287, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
(54) Generate
Input [23]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderSchedule#3004, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220]
Arguments: explode(productOrderSchedule#3004), [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220], false, [productOrderScheduleExploded#3301]
(55) Project
Output [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, productOrderScheduleExploded#3301.product AS product#3315, productOrderScheduleExploded#3301.orderDateTime AS orderDateTime#3316, productOrderScheduleExploded#3301.availabilityDateTime AS availabilityDateTime#3317, productOrderScheduleExploded#3301.nextAvailabilityDateTime AS nextAvailabilityDateTime#3318, productOrderScheduleExploded#3301.mrpController AS mrpController#3319, productOrderScheduleExploded#3301.sourceOfSupplyUuid AS sourceOfSupplyUuid#3320, productOrderScheduleExploded#3301.purchasingOrg AS purchasingOrg#3321, productOrderScheduleExploded#3301.purchasingGroup AS purchasingGroup#3322, xxhash64(CASE WHEN (_extract_supplier#4175 <=> true) THEN supplierOrGroup#3208 END, CASE WHEN (_extract_deliveryDate#4176 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_orderDate#4177 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_supplierSubrange#4178 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_purchasingOrg#4179 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_mrpController#4180 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4181 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, locationOrGroup#3220, ((((((((CASE WHEN (isnull(supplierOrGroup#3208) AND (_extract_supplier#4175 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4176 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4177 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4178 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4179 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4180 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4181 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(locationOrGroup#3220) THEN 256 ELSE 0 END), 10000000095, 42) AS orderProposalId#3715L, 0 AS orderProposalHorizonGroupingId#3736L, xxhash64(CASE WHEN (_extract_purchasingOrg#4182 <=> true) THEN productOrderScheduleExploded#3301.purchasingOrg END, CASE WHEN (_extract_deliveryDate#4183 <=> true) THEN deliveryDateTime#3002 END, CASE WHEN (_extract_supplier#4184 <=> true) THEN supplier#3000 END, CASE WHEN (_extract_supplierSubrange#4185 <=> true) THEN subrange#3003 END, CASE WHEN (_extract_orderDate#4186 <=> true) THEN productOrderScheduleExploded#3301.orderDateTime END, CASE WHEN (_extract_mrpController#4187 <=> true) THEN productOrderScheduleExploded#3301.mrpController END, orderGroupingProfile#3015, CASE WHEN (_extract_purchasingGroup#4188 <=> true) THEN productOrderScheduleExploded#3301.purchasingGroup END, plant#3001, ((((((((CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingOrg) AND (_extract_purchasingOrg#4182 <=> true)) THEN 1 ELSE 0 END + CASE WHEN (isnull(deliveryDateTime#3002) AND (_extract_deliveryDate#4183 <=> true)) THEN 2 ELSE 0 END) + CASE WHEN (isnull(supplier#3000) AND (_extract_supplier#4184 <=> true)) THEN 4 ELSE 0 END) + CASE WHEN (isnull(subrange#3003) AND (_extract_supplierSubrange#4185 <=> true)) THEN 8 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.orderDateTime) AND (_extract_orderDate#4186 <=> true)) THEN 16 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.mrpController) AND (_extract_mrpController#4187 <=> true)) THEN 32 ELSE 0 END) + CASE WHEN isnull(orderGroupingProfile#3015) THEN 64 ELSE 0 END) + CASE WHEN (isnull(productOrderScheduleExploded#3301.purchasingGroup) AND (_extract_purchasingGroup#4188 <=> true)) THEN 128 ELSE 0 END) + CASE WHEN isnull(plant#3001) THEN 256 ELSE 0 END), 10000000095, 42) AS splitIndicator#4136L]
Input [23]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, _extract_supplier#4175, _extract_deliveryDate#4176, _extract_orderDate#4177, _extract_supplierSubrange#4178, _extract_purchasingOrg#4179, _extract_mrpController#4180, _extract_purchasingGroup#4181, _extract_purchasingOrg#4182, _extract_deliveryDate#4183, _extract_supplier#4184, _extract_supplierSubrange#4185, _extract_orderDate#4186, _extract_mrpController#4187, _extract_purchasingGroup#4188, orderGroupingProfile#3015, supplierOrGroup#3208, locationOrGroup#3220, productOrderScheduleExploded#3301]
(56) AdaptiveSparkPlan
Output [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: isFinalPlan=true
(57) TableCacheQueryStage
Output [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: 0
(58) Exchange
Input [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: SinglePartition, REPARTITION_BY_NUM, [plan_id=2268]
(59) ShuffleQueryStage
Output [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: 1
(60) Exchange
Input [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: SinglePartition, REPARTITION_BY_NUM, [plan_id=2208]
(61) AdaptiveSparkPlan
Output [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: isFinalPlan=true
(62) TableCacheQueryStage
Output [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: 0
(63) DeserializeToObject
Input [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: createexternalrow(supplierGroup#2999.toString, supplier#3000.toString, plant#3001.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, deliveryDateTime#3002, true, false, true), subrange#3003.toString, product#3315.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, orderDateTime#3316, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, availabilityDateTime#3317, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, nextAvailabilityDateTime#3318, true, false, true), mrpController#3319.toString, sourceOfSupplyUuid#3320.toString, purchasingOrg#3321.toString, purchasingGroup#3322.toString, staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalId#3715L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalHorizonGroupingId#3736L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, splitIndicator#4136L, true, false, true), StructField(supplierGroup,StringType,true), StructField(supplier,StringType,true), StructField(plant,StringType,true), StructField(deliveryDateTime,TimestampType,true), StructField(subrange,StringType,true), StructField(product,StringType,true), StructField(orderDateTime,TimestampType,true), StructField(availabilityDateTime,TimestampType,true), ... 8 more fields), obj#5842: org.apache.spark.sql.Row
(64) MapPartitions
Input [1]: [obj#5842]
Arguments: org.apache.spark.sql.Dataset$$Lambda$7144/0x00007f71e9afe200@60ecfd47, obj#5843: org.apache.spark.sql.Row
(65) SerializeFromObject [codegen id : 1]
Input [1]: [obj#5843]
Arguments: [if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 0, supplierGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplierGroup#5844, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 1, supplier), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplier#5845, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 2, plant), StringType, ObjectType(class java.lang.String)), true, false, true) AS plant#5846, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 3, deliveryDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS deliveryDateTime#5847, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 4, subrange), StringType, ObjectType(class java.lang.String)), true, false, true) AS subrange#5848, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 5, product), StringType, ObjectType(class java.lang.String)), true, false, true) AS product#5849, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 6, orderDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS orderDateTime#5850, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 7, availabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS availabilityDateTime#5851, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 8, nextAvailabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS nextAvailabilityDateTime#5852, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 9, mrpController), StringType, ObjectType(class java.lang.String)), true, false, true) AS mrpController#5853, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 10, sourceOfSupplyUuid), StringType, ObjectType(class java.lang.String)), true, false, true) AS sourceOfSupplyUuid#5854, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 11, purchasingOrg), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingOrg#5855, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 12, purchasingGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingGroup#5856, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 13, orderProposalId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalId#5857L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 14, orderProposalHorizonGroupingId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalHorizonGroupingId#5858L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 15, splitIndicator), LongType, ObjectType(class java.lang.Long)).longValue) AS splitIndicator#5859L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 16, binId), IntegerType, ObjectType(class java.lang.Integer)).intValue) AS binId#5860]
(66) DeserializeToObject
Input [16]: [supplierGroup#2999, supplier#3000, plant#3001, deliveryDateTime#3002, subrange#3003, product#3315, orderDateTime#3316, availabilityDateTime#3317, nextAvailabilityDateTime#3318, mrpController#3319, sourceOfSupplyUuid#3320, purchasingOrg#3321, purchasingGroup#3322, orderProposalId#3715L, orderProposalHorizonGroupingId#3736L, splitIndicator#4136L]
Arguments: createexternalrow(supplierGroup#2999.toString, supplier#3000.toString, plant#3001.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, deliveryDateTime#3002, true, false, true), subrange#3003.toString, product#3315.toString, staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, orderDateTime#3316, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, availabilityDateTime#3317, true, false, true), staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, ObjectType(class java.sql.Timestamp), toJavaTimestamp, nextAvailabilityDateTime#3318, true, false, true), mrpController#3319.toString, sourceOfSupplyUuid#3320.toString, purchasingOrg#3321.toString, purchasingGroup#3322.toString, staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalId#3715L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, orderProposalHorizonGroupingId#3736L, true, false, true), staticinvoke(class java.lang.Long, ObjectType(class java.lang.Long), valueOf, splitIndicator#4136L, true, false, true), StructField(supplierGroup,StringType,true), StructField(supplier,StringType,true), StructField(plant,StringType,true), StructField(deliveryDateTime,TimestampType,true), StructField(subrange,StringType,true), StructField(product,StringType,true), StructField(orderDateTime,TimestampType,true), StructField(availabilityDateTime,TimestampType,true), ... 8 more fields), obj#5842: org.apache.spark.sql.Row
(67) MapPartitions
Input [1]: [obj#5842]
Arguments: org.apache.spark.sql.Dataset$$Lambda$7144/0x00007f71e9afe200@60ecfd47, obj#5843: org.apache.spark.sql.Row
(68) SerializeFromObject
Input [1]: [obj#5843]
Arguments: [if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 0, supplierGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplierGroup#5844, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 1, supplier), StringType, ObjectType(class java.lang.String)), true, false, true) AS supplier#5845, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 2, plant), StringType, ObjectType(class java.lang.String)), true, false, true) AS plant#5846, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 3, deliveryDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS deliveryDateTime#5847, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 4, subrange), StringType, ObjectType(class java.lang.String)), true, false, true) AS subrange#5848, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 5, product), StringType, ObjectType(class java.lang.String)), true, false, true) AS product#5849, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 6, orderDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS orderDateTime#5850, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 7, availabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS availabilityDateTime#5851, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.sql.catalyst.util.DateTimeUtils$, TimestampType, fromJavaTimestamp, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 8, nextAvailabilityDateTime), TimestampType, ObjectType(class java.sql.Timestamp)), true, false, true) AS nextAvailabilityDateTime#5852, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 9, mrpController), StringType, ObjectType(class java.lang.String)), true, false, true) AS mrpController#5853, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 10, sourceOfSupplyUuid), StringType, ObjectType(class java.lang.String)), true, false, true) AS sourceOfSupplyUuid#5854, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 11, purchasingOrg), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingOrg#5855, if (assertnotnull(input[0, org.apache.spark.sql.Row, true]).isNullAt) null else staticinvoke(class org.apache.spark.unsafe.types.UTF8String, StringType, fromString, validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 12, purchasingGroup), StringType, ObjectType(class java.lang.String)), true, false, true) AS purchasingGroup#5856, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 13, orderProposalId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalId#5857L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 14, orderProposalHorizonGroupingId), LongType, ObjectType(class java.lang.Long)).longValue) AS orderProposalHorizonGroupingId#5858L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 15, splitIndicator), LongType, ObjectType(class java.lang.Long)).longValue) AS splitIndicator#5859L, assertnotnull(validateexternaltype(getexternalrowfield(assertnotnull(input[0, org.apache.spark.sql.Row, true]), 16, binId), IntegerType, ObjectType(class java.lang.Integer)).intValue) AS binId#5860]
(69) AdaptiveSparkPlan
Output [17]: [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, binId#5860]
Arguments: isFinalPlan=true
(70) TableCacheQueryStage
Output [17]: [availabilityDateTime#5851, binId#5860, deliveryDateTime#5847, mrpController#5853, nextAvailabilityDateTime#5852, orderDateTime#5850, orderProposalHorizonGroupingId#5858L, orderProposalId#5857L, plant#5846, product#5849, purchasingGroup#5856, purchasingOrg#5855, sourceOfSupplyUuid#5854, splitIndicator#5859L, subrange#5848, supplier#5845, supplierGroup#5844]
Arguments: 0
(71) Project [codegen id : 1]
Output [18]: [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, concat(0, _, cast(binId#5860 as string), _, 10000000095) AS shardId#6186, monotonically_increasing_id() AS worklistShardItemId#6222L]
Input [17]: [availabilityDateTime#5851, binId#5860, deliveryDateTime#5847, mrpController#5853, nextAvailabilityDateTime#5852, orderDateTime#5850, orderProposalHorizonGroupingId#5858L, orderProposalId#5857L, plant#5846, product#5849, purchasingGroup#5856, purchasingOrg#5855, sourceOfSupplyUuid#5854, splitIndicator#5859L, subrange#5848, supplier#5845, supplierGroup#5844]
(72) Project [codegen id : 1]
Output [20]: [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, shardId#6186, worklistShardItemId#6222L, null AS orderProposalItemGroupId#6241, cast((monotonically_increasing_id() % 9999999999) as string) AS orderProposalItemId#6261]
Input [18]: [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, shardId#6186, worklistShardItemId#6222L]
(73) Project
Output [18]: [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, concat(0, _, cast(binId#5860 as string), _, 10000000095) AS shardId#6186, monotonically_increasing_id() AS worklistShardItemId#6222L]
Input [17]: [availabilityDateTime#5851, binId#5860, deliveryDateTime#5847, mrpController#5853, nextAvailabilityDateTime#5852, orderDateTime#5850, orderProposalHorizonGroupingId#5858L, orderProposalId#5857L, plant#5846, product#5849, purchasingGroup#5856, purchasingOrg#5855, sourceOfSupplyUuid#5854, splitIndicator#5859L, subrange#5848, supplier#5845, supplierGroup#5844]
(74) Project
Output [20]: [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, shardId#6186, worklistShardItemId#6222L, null AS orderProposalItemGroupId#6241, cast((monotonically_increasing_id() % 9999999999) as string) AS orderProposalItemId#6261]
Input [18]: [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, shardId#6186, worklistShardItemId#6222L]
(75) AdaptiveSparkPlan
Output [20]: [supplierGroup#5844, supplier#5845, plant#5846, deliveryDateTime#5847, subrange#5848, product#5849, orderDateTime#5850, availabilityDateTime#5851, nextAvailabilityDateTime#5852, mrpController#5853, sourceOfSupplyUuid#5854, purchasingOrg#5855, purchasingGroup#5856, orderProposalId#5857L, orderProposalHorizonGroupingId#5858L, splitIndicator#5859L, shardId#6186, worklistShardItemId#6222L, orderProposalItemGroupId#6241, orderProposalItemId#6261]
Arguments: isFinalPlan=true
(76) TableCacheQueryStage
Output [1]: [shardId#6186]
Arguments: 0
(77) HashAggregate [codegen id : 1]
Input [1]: [shardId#6186]
Keys [1]: [shardId#6186]
Functions: []
Aggregate Attributes: []
Results [1]: [shardId#6186]
(78) HashAggregate [codegen id : 1]
Input [1]: [shardId#6186]
Keys [1]: [shardId#6186]
Functions: []
Aggregate Attributes: []
Results [1]: [shardId#6186]
(79) HashAggregate
Input [1]: [shardId#6186]
Keys [1]: [shardId#6186]
Functions: []
Aggregate Attributes: []
Results [1]: [shardId#6186]
(80) Exchange
Input [1]: [shardId#6186]
Arguments: hashpartitioning(shardId#6186, 25), ENSURE_REQUIREMENTS, [plan_id=2247]
(81) HashAggregate
Input [1]: [shardId#6186]
Keys [1]: [shardId#6186]
Functions: []
Aggregate Attributes: []
Results [1]: [shardId#6186]
(82) AdaptiveSparkPlan
Output [1]: [shardId#6186]
Arguments: isFinalPlan=true