WholeStageCodegen (11)
  Filter [paid]
    Subquery #1
      WholeStageCodegen (11)
        HashAggregate [sum,count] [avg(netpaid),(0.05 * avg(netpaid)),sum,count]
          InputAdapter
            Exchange #9
              WholeStageCodegen (10)
                HashAggregate [netpaid] [sum,count,sum,count]
                  HashAggregate [c_last_name,c_first_name,s_store_name,ca_state,s_state,i_color,i_current_price,i_manager_id,i_units,i_size,sum] [sum(UnscaledValue(ss_net_paid)),netpaid,sum]
                    InputAdapter
                      Exchange [c_last_name,c_first_name,s_store_name,ca_state,s_state,i_color,i_current_price,i_manager_id,i_units,i_size] #10
                        WholeStageCodegen (9)
                          HashAggregate [c_last_name,c_first_name,s_store_name,ca_state,s_state,i_color,i_current_price,i_manager_id,i_units,i_size,ss_net_paid] [sum,sum]
                            Project [ss_net_paid,s_store_name,s_state,i_current_price,i_size,i_color,i_units,i_manager_id,c_first_name,c_last_name,ca_state]
                              BroadcastHashJoin [c_birth_country,s_zip,ca_country,ca_zip]
                                Project [ss_net_paid,s_store_name,s_state,s_zip,i_current_price,i_size,i_color,i_units,i_manager_id,c_first_name,c_last_name,c_birth_country]
                                  BroadcastHashJoin [ss_customer_sk,c_customer_sk]
                                    Project [ss_customer_sk,ss_net_paid,s_store_name,s_state,s_zip,i_current_price,i_size,i_color,i_units,i_manager_id]
                                      BroadcastHashJoin [ss_item_sk,i_item_sk]
                                        Project [ss_item_sk,ss_customer_sk,ss_net_paid,s_store_name,s_state,s_zip]
                                          BroadcastHashJoin [ss_store_sk,s_store_sk]
                                            Project [ss_item_sk,ss_customer_sk,ss_store_sk,ss_net_paid]
                                              SortMergeJoin [ss_ticket_number,ss_item_sk,sr_ticket_number,sr_item_sk]
                                                InputAdapter
                                                  WholeStageCodegen (2)
                                                    Sort [ss_ticket_number,ss_item_sk]
                                                      InputAdapter
                                                        ReusedExchange [ss_item_sk,ss_customer_sk,ss_store_sk,ss_ticket_number,ss_net_paid] #3
                                                InputAdapter
                                                  WholeStageCodegen (4)
                                                    Sort [sr_ticket_number,sr_item_sk]
                                                      InputAdapter
                                                        ReusedExchange [sr_item_sk,sr_ticket_number] #4
                                            InputAdapter
                                              ReusedExchange [s_store_sk,s_store_name,s_state,s_zip] #5
                                        InputAdapter
                                          BroadcastExchange #11
                                            WholeStageCodegen (6)
                                              Filter [i_item_sk]
                                                ColumnarToRow
                                                  InputAdapter
                                                    Scan parquet spark_catalog.default.item [i_item_sk,i_current_price,i_size,i_color,i_units,i_manager_id]
                                    InputAdapter
                                      ReusedExchange [c_customer_sk,c_first_name,c_last_name,c_birth_country] #7
                                InputAdapter
                                  ReusedExchange [ca_state,ca_zip,ca_country] #8
    HashAggregate [c_last_name,c_first_name,s_store_name,sum,isEmpty] [sum(netpaid),paid,sum,isEmpty]
      InputAdapter
        Exchange [c_last_name,c_first_name,s_store_name] #1
          WholeStageCodegen (10)
            HashAggregate [c_last_name,c_first_name,s_store_name,netpaid] [sum,isEmpty,sum,isEmpty]
              HashAggregate [c_last_name,c_first_name,s_store_name,ca_state,s_state,i_color,i_current_price,i_manager_id,i_units,i_size,sum] [sum(UnscaledValue(ss_net_paid)),netpaid,sum]
                InputAdapter
                  Exchange [c_last_name,c_first_name,s_store_name,ca_state,s_state,i_color,i_current_price,i_manager_id,i_units,i_size] #2
                    WholeStageCodegen (9)
                      HashAggregate [c_last_name,c_first_name,s_store_name,ca_state,s_state,i_color,i_current_price,i_manager_id,i_units,i_size,ss_net_paid] [sum,sum]
                        Project [ss_net_paid,s_store_name,s_state,i_current_price,i_size,i_color,i_units,i_manager_id,c_first_name,c_last_name,ca_state]
                          BroadcastHashJoin [c_birth_country,s_zip,ca_country,ca_zip]
                            Project [ss_net_paid,s_store_name,s_state,s_zip,i_current_price,i_size,i_color,i_units,i_manager_id,c_first_name,c_last_name,c_birth_country]
                              BroadcastHashJoin [ss_customer_sk,c_customer_sk]
                                Project [ss_customer_sk,ss_net_paid,s_store_name,s_state,s_zip,i_current_price,i_size,i_color,i_units,i_manager_id]
                                  BroadcastHashJoin [ss_item_sk,i_item_sk]
                                    Project [ss_item_sk,ss_customer_sk,ss_net_paid,s_store_name,s_state,s_zip]
                                      BroadcastHashJoin [ss_store_sk,s_store_sk]
                                        Project [ss_item_sk,ss_customer_sk,ss_store_sk,ss_net_paid]
                                          SortMergeJoin [ss_ticket_number,ss_item_sk,sr_ticket_number,sr_item_sk]
                                            InputAdapter
                                              WholeStageCodegen (2)
                                                Sort [ss_ticket_number,ss_item_sk]
                                                  InputAdapter
                                                    Exchange [ss_ticket_number,ss_item_sk] #3
                                                      WholeStageCodegen (1)
                                                        Project [ss_item_sk,ss_customer_sk,ss_store_sk,ss_ticket_number,ss_net_paid]
                                                          Filter [ss_ticket_number,ss_item_sk,ss_store_sk,ss_customer_sk]
                                                            ColumnarToRow
                                                              InputAdapter
                                                                Scan parquet spark_catalog.default.store_sales [ss_item_sk,ss_customer_sk,ss_store_sk,ss_ticket_number,ss_net_paid,ss_sold_date_sk]
                                            InputAdapter
                                              WholeStageCodegen (4)
                                                Sort [sr_ticket_number,sr_item_sk]
                                                  InputAdapter
                                                    Exchange [sr_ticket_number,sr_item_sk] #4
                                                      WholeStageCodegen (3)
                                                        Project [sr_item_sk,sr_ticket_number]
                                                          Filter [sr_ticket_number,sr_item_sk]
                                                            ColumnarToRow
                                                              InputAdapter
                                                                Scan parquet spark_catalog.default.store_returns [sr_item_sk,sr_ticket_number,sr_returned_date_sk]
                                        InputAdapter
                                          BroadcastExchange #5
                                            WholeStageCodegen (5)
                                              Project [s_store_sk,s_store_name,s_state,s_zip]
                                                Filter [s_market_id,s_store_sk,s_zip]
                                                  ColumnarToRow
                                                    InputAdapter
                                                      Scan parquet spark_catalog.default.store [s_store_sk,s_store_name,s_market_id,s_state,s_zip]
                                    InputAdapter
                                      BroadcastExchange #6
                                        WholeStageCodegen (6)
                                          Filter [i_color,i_item_sk]
                                            ColumnarToRow
                                              InputAdapter
                                                Scan parquet spark_catalog.default.item [i_item_sk,i_current_price,i_size,i_color,i_units,i_manager_id]
                                InputAdapter
                                  BroadcastExchange #7
                                    WholeStageCodegen (7)
                                      Filter [c_customer_sk,c_birth_country]
                                        ColumnarToRow
                                          InputAdapter
                                            Scan parquet spark_catalog.default.customer [c_customer_sk,c_first_name,c_last_name,c_birth_country]
                            InputAdapter
                              BroadcastExchange #8
                                WholeStageCodegen (8)
                                  Filter [ca_country,ca_zip]
                                    ColumnarToRow
                                      InputAdapter
                                        Scan parquet spark_catalog.default.customer_address [ca_state,ca_zip,ca_country]
