final aggregation over ()
    local exchange (GATHER, SINGLE, [])
        remote exchange (GATHER, SINGLE, [])
            partial aggregation over ()
                join (FULL, PARTITIONED):
                    final aggregation over (ss_customer_sk, ss_item_sk)
                        local exchange (GATHER, SINGLE, [])
                            remote exchange (REPARTITION, HASH, [ss_customer_sk, ss_item_sk])
                                partial aggregation over (ss_customer_sk, ss_item_sk)
                                    join (INNER, REPLICATED):
                                        scan store_sales
                                        local exchange (GATHER, SINGLE, [])
                                            remote exchange (REPLICATE, BROADCAST, [])
                                                scan date_dim
                    final aggregation over (cs_bill_customer_sk, cs_item_sk)
                        local exchange (GATHER, SINGLE, [])
                            remote exchange (REPARTITION, HASH, [cs_bill_customer_sk, cs_item_sk])
                                partial aggregation over (cs_bill_customer_sk, cs_item_sk)
                                    join (INNER, REPLICATED):
                                        scan catalog_sales
                                        local exchange (GATHER, SINGLE, [])
                                            remote exchange (REPLICATE, BROADCAST, [])
                                                scan date_dim
