== Physical Plan ==
* HashAggregate (25)
+- Exchange (24)
   +- * HashAggregate (23)
      +- * ColumnarToRow (22)
         +- CometProject (21)
            +- CometSortMergeJoin (20)
               :- CometSort (11)
               :  +- CometHashAggregate (10)
               :     +- CometExchange (9)
               :        +- CometHashAggregate (8)
               :           +- CometProject (7)
               :              +- CometBroadcastHashJoin (6)
               :                 :- CometNativeScan: `spark_catalog`.`default`.`store_sales` (1)
               :                 +- CometBroadcastExchange (5)
               :                    +- CometProject (4)
               :                       +- CometFilter (3)
               :                          +- CometNativeScan: `spark_catalog`.`default`.`date_dim` (2)
               +- CometSort (19)
                  +- CometHashAggregate (18)
                     +- CometExchange (17)
                        +- CometHashAggregate (16)
                           +- CometProject (15)
                              +- CometBroadcastHashJoin (14)
                                 :- CometNativeScan: `spark_catalog`.`default`.`catalog_sales` (12)
                                 +- ReusedExchange (13)


(1) CometNativeScan: `spark_catalog`.`default`.`store_sales`
Output [3]: [ss_item_sk#1, ss_customer_sk#2, ss_sold_date_sk#3]
Arguments: [ss_item_sk#1, ss_customer_sk#2, ss_sold_date_sk#3]

(2) CometNativeScan: `spark_catalog`.`default`.`date_dim`
Output [2]: [d_date_sk#4, d_month_seq#5]
Arguments: [d_date_sk#4, d_month_seq#5]

(3) CometFilter
Input [2]: [d_date_sk#4, d_month_seq#5]
Condition : (((isnotnull(d_month_seq#5) AND (d_month_seq#5 >= 1200)) AND (d_month_seq#5 <= 1211)) AND isnotnull(d_date_sk#4))

(4) CometProject
Input [2]: [d_date_sk#4, d_month_seq#5]
Arguments: [d_date_sk#4], [d_date_sk#4]

(5) CometBroadcastExchange
Input [1]: [d_date_sk#4]
Arguments: [d_date_sk#4]

(6) CometBroadcastHashJoin
Left output [3]: [ss_item_sk#1, ss_customer_sk#2, ss_sold_date_sk#3]
Right output [1]: [d_date_sk#4]
Arguments: [ss_sold_date_sk#3], [d_date_sk#4], Inner, BuildRight

(7) CometProject
Input [4]: [ss_item_sk#1, ss_customer_sk#2, ss_sold_date_sk#3, d_date_sk#4]
Arguments: [ss_item_sk#1, ss_customer_sk#2], [ss_item_sk#1, ss_customer_sk#2]

(8) CometHashAggregate
Input [2]: [ss_item_sk#1, ss_customer_sk#2]
Keys [2]: [ss_customer_sk#2, ss_item_sk#1]
Functions: []

(9) CometExchange
Input [2]: [ss_customer_sk#2, ss_item_sk#1]
Arguments: hashpartitioning(ss_customer_sk#2, ss_item_sk#1, 5), ENSURE_REQUIREMENTS, CometNativeShuffle, [plan_id=1]

(10) CometHashAggregate
Input [2]: [ss_customer_sk#2, ss_item_sk#1]
Keys [2]: [ss_customer_sk#2, ss_item_sk#1]
Functions: []

(11) CometSort
Input [2]: [customer_sk#6, item_sk#7]
Arguments: [customer_sk#6, item_sk#7], [customer_sk#6 ASC NULLS FIRST, item_sk#7 ASC NULLS FIRST]

(12) CometNativeScan: `spark_catalog`.`default`.`catalog_sales`
Output [3]: [cs_bill_customer_sk#8, cs_item_sk#9, cs_sold_date_sk#10]
Arguments: [cs_bill_customer_sk#8, cs_item_sk#9, cs_sold_date_sk#10]

(13) ReusedExchange [Reuses operator id: 5]
Output [1]: [d_date_sk#11]

(14) CometBroadcastHashJoin
Left output [3]: [cs_bill_customer_sk#8, cs_item_sk#9, cs_sold_date_sk#10]
Right output [1]: [d_date_sk#11]
Arguments: [cs_sold_date_sk#10], [d_date_sk#11], Inner, BuildRight

(15) CometProject
Input [4]: [cs_bill_customer_sk#8, cs_item_sk#9, cs_sold_date_sk#10, d_date_sk#11]
Arguments: [cs_bill_customer_sk#8, cs_item_sk#9], [cs_bill_customer_sk#8, cs_item_sk#9]

(16) CometHashAggregate
Input [2]: [cs_bill_customer_sk#8, cs_item_sk#9]
Keys [2]: [cs_bill_customer_sk#8, cs_item_sk#9]
Functions: []

(17) CometExchange
Input [2]: [cs_bill_customer_sk#8, cs_item_sk#9]
Arguments: hashpartitioning(cs_bill_customer_sk#8, cs_item_sk#9, 5), ENSURE_REQUIREMENTS, CometNativeShuffle, [plan_id=2]

(18) CometHashAggregate
Input [2]: [cs_bill_customer_sk#8, cs_item_sk#9]
Keys [2]: [cs_bill_customer_sk#8, cs_item_sk#9]
Functions: []

(19) CometSort
Input [2]: [customer_sk#12, item_sk#13]
Arguments: [customer_sk#12, item_sk#13], [customer_sk#12 ASC NULLS FIRST, item_sk#13 ASC NULLS FIRST]

(20) CometSortMergeJoin
Left output [2]: [customer_sk#6, item_sk#7]
Right output [2]: [customer_sk#12, item_sk#13]
Arguments: [customer_sk#6, item_sk#7], [customer_sk#12, item_sk#13], FullOuter

(21) CometProject
Input [4]: [customer_sk#6, item_sk#7, customer_sk#12, item_sk#13]
Arguments: [customer_sk#6, customer_sk#12], [customer_sk#6, customer_sk#12]

(22) ColumnarToRow [codegen id : 1]
Input [2]: [customer_sk#6, customer_sk#12]

(23) HashAggregate [codegen id : 1]
Input [2]: [customer_sk#6, customer_sk#12]
Keys: []
Functions [3]: [partial_sum(CASE WHEN (isnotnull(customer_sk#6) AND isnull(customer_sk#12)) THEN 1 ELSE 0 END), partial_sum(CASE WHEN (isnull(customer_sk#6) AND isnotnull(customer_sk#12)) THEN 1 ELSE 0 END), partial_sum(CASE WHEN (isnotnull(customer_sk#6) AND isnotnull(customer_sk#12)) THEN 1 ELSE 0 END)]
Aggregate Attributes [3]: [sum#14, sum#15, sum#16]
Results [3]: [sum#17, sum#18, sum#19]

(24) Exchange
Input [3]: [sum#17, sum#18, sum#19]
Arguments: SinglePartition, ENSURE_REQUIREMENTS, [plan_id=3]

(25) HashAggregate [codegen id : 2]
Input [3]: [sum#17, sum#18, sum#19]
Keys: []
Functions [3]: [sum(CASE WHEN (isnotnull(customer_sk#6) AND isnull(customer_sk#12)) THEN 1 ELSE 0 END), sum(CASE WHEN (isnull(customer_sk#6) AND isnotnull(customer_sk#12)) THEN 1 ELSE 0 END), sum(CASE WHEN (isnotnull(customer_sk#6) AND isnotnull(customer_sk#12)) THEN 1 ELSE 0 END)]
Aggregate Attributes [3]: [sum(CASE WHEN (isnotnull(customer_sk#6) AND isnull(customer_sk#12)) THEN 1 ELSE 0 END)#20, sum(CASE WHEN (isnull(customer_sk#6) AND isnotnull(customer_sk#12)) THEN 1 ELSE 0 END)#21, sum(CASE WHEN (isnotnull(customer_sk#6) AND isnotnull(customer_sk#12)) THEN 1 ELSE 0 END)#22]
Results [3]: [sum(CASE WHEN (isnotnull(customer_sk#6) AND isnull(customer_sk#12)) THEN 1 ELSE 0 END)#20 AS store_only#23, sum(CASE WHEN (isnull(customer_sk#6) AND isnotnull(customer_sk#12)) THEN 1 ELSE 0 END)#21 AS catalog_only#24, sum(CASE WHEN (isnotnull(customer_sk#6) AND isnotnull(customer_sk#12)) THEN 1 ELSE 0 END)#22 AS store_and_catalog#25]

