TakeOrderedAndProject [i_item_id,i_item_desc,s_store_id,s_store_name,store_sales_profit,store_returns_loss,catalog_sales_profit]
  WholeStageCodegen (18)
    HashAggregate [i_item_id,i_item_desc,s_store_id,s_store_name,sum,sum,sum] [sum(UnscaledValue(ss_net_profit)),sum(UnscaledValue(sr_net_loss)),sum(UnscaledValue(cs_net_profit)),store_sales_profit,store_returns_loss,catalog_sales_profit,sum,sum,sum]
      InputAdapter
        Exchange [i_item_id,i_item_desc,s_store_id,s_store_name] #1
          WholeStageCodegen (17)
            HashAggregate [i_item_id,i_item_desc,s_store_id,s_store_name,ss_net_profit,sr_net_loss,cs_net_profit] [sum,sum,sum,sum,sum,sum]
              Project [ss_net_profit,sr_net_loss,cs_net_profit,s_store_id,s_store_name,i_item_id,i_item_desc]
                SortMergeJoin [sr_customer_sk,sr_item_sk,cs_bill_customer_sk,cs_item_sk]
                  InputAdapter
                    WholeStageCodegen (13)
                      Sort [sr_customer_sk,sr_item_sk]
                        InputAdapter
                          Exchange [sr_customer_sk,sr_item_sk] #2
                            WholeStageCodegen (12)
                              Project [ss_net_profit,s_store_id,s_store_name,i_item_id,i_item_desc,sr_item_sk,sr_customer_sk,sr_net_loss]
                                SortMergeJoin [ss_customer_sk,ss_item_sk,ss_ticket_number,sr_customer_sk,sr_item_sk,sr_ticket_number]
                                  InputAdapter
                                    WholeStageCodegen (8)
                                      Sort [ss_customer_sk,ss_item_sk,ss_ticket_number]
                                        InputAdapter
                                          Exchange [ss_customer_sk,ss_item_sk,ss_ticket_number] #3
                                            WholeStageCodegen (7)
                                              Project [ss_item_sk,ss_customer_sk,ss_ticket_number,ss_net_profit,s_store_id,s_store_name,i_item_id,i_item_desc]
                                                SortMergeJoin [ss_item_sk,i_item_sk]
                                                  InputAdapter
                                                    WholeStageCodegen (4)
                                                      Sort [ss_item_sk]
                                                        InputAdapter
                                                          Exchange [ss_item_sk] #4
                                                            WholeStageCodegen (3)
                                                              Project [ss_item_sk,ss_customer_sk,ss_ticket_number,ss_net_profit,s_store_id,s_store_name]
                                                                BroadcastHashJoin [ss_store_sk,s_store_sk]
                                                                  Project [ss_item_sk,ss_customer_sk,ss_store_sk,ss_ticket_number,ss_net_profit]
                                                                    BroadcastHashJoin [ss_sold_date_sk,d_date_sk]
                                                                      Filter [ss_customer_sk,ss_item_sk,ss_ticket_number,ss_store_sk]
                                                                        ColumnarToRow
                                                                          InputAdapter
                                                                            Scan parquet spark_catalog.default.store_sales [ss_item_sk,ss_customer_sk,ss_store_sk,ss_ticket_number,ss_net_profit,ss_sold_date_sk]
                                                                              SubqueryBroadcast [d_date_sk] #1
                                                                                BroadcastExchange #5
                                                                                  WholeStageCodegen (1)
                                                                                    Project [d_date_sk]
                                                                                      Filter [d_moy,d_year,d_date_sk]
                                                                                        ColumnarToRow
                                                                                          InputAdapter
                                                                                            Scan parquet spark_catalog.default.date_dim [d_date_sk,d_year,d_moy]
                                                                      InputAdapter
                                                                        ReusedExchange [d_date_sk] #5
                                                                  InputAdapter
                                                                    BroadcastExchange #6
                                                                      WholeStageCodegen (2)
                                                                        Filter [s_store_sk]
                                                                          ColumnarToRow
                                                                            InputAdapter
                                                                              Scan parquet spark_catalog.default.store [s_store_sk,s_store_id,s_store_name]
                                                  InputAdapter
                                                    WholeStageCodegen (6)
                                                      Sort [i_item_sk]
                                                        InputAdapter
                                                          Exchange [i_item_sk] #7
                                                            WholeStageCodegen (5)
                                                              Filter [i_item_sk]
                                                                ColumnarToRow
                                                                  InputAdapter
                                                                    Scan parquet spark_catalog.default.item [i_item_sk,i_item_id,i_item_desc]
                                  InputAdapter
                                    WholeStageCodegen (11)
                                      Sort [sr_customer_sk,sr_item_sk,sr_ticket_number]
                                        InputAdapter
                                          Exchange [sr_customer_sk,sr_item_sk,sr_ticket_number] #8
                                            WholeStageCodegen (10)
                                              Project [sr_item_sk,sr_customer_sk,sr_ticket_number,sr_net_loss]
                                                BroadcastHashJoin [sr_returned_date_sk,d_date_sk]
                                                  Filter [sr_customer_sk,sr_item_sk,sr_ticket_number]
                                                    ColumnarToRow
                                                      InputAdapter
                                                        Scan parquet spark_catalog.default.store_returns [sr_item_sk,sr_customer_sk,sr_ticket_number,sr_net_loss,sr_returned_date_sk]
                                                          SubqueryBroadcast [d_date_sk] #2
                                                            BroadcastExchange #9
                                                              WholeStageCodegen (1)
                                                                Project [d_date_sk]
                                                                  Filter [d_moy,d_year,d_date_sk]
                                                                    ColumnarToRow
                                                                      InputAdapter
                                                                        Scan parquet spark_catalog.default.date_dim [d_date_sk,d_year,d_moy]
                                                  InputAdapter
                                                    ReusedExchange [d_date_sk] #9
                  InputAdapter
                    WholeStageCodegen (16)
                      Sort [cs_bill_customer_sk,cs_item_sk]
                        InputAdapter
                          Exchange [cs_bill_customer_sk,cs_item_sk] #10
                            WholeStageCodegen (15)
                              Project [cs_bill_customer_sk,cs_item_sk,cs_net_profit]
                                BroadcastHashJoin [cs_sold_date_sk,d_date_sk]
                                  Filter [cs_bill_customer_sk,cs_item_sk]
                                    ColumnarToRow
                                      InputAdapter
                                        Scan parquet spark_catalog.default.catalog_sales [cs_bill_customer_sk,cs_item_sk,cs_net_profit,cs_sold_date_sk]
                                          ReusedSubquery [d_date_sk] #2
                                  InputAdapter
                                    ReusedExchange [d_date_sk] #9
