SELECT a.coupon_upc,a.coup_desc,a.coup_dep,a.manuf,a.coupon_type,r.hh_red,r.red_qty,
r.red_val,a.coups_mailed,a.households_mailed
FROM
(SELECT coupon_upc,
min(coupon_description) coup_desc,
min(campaign_manufacturer_desc) manuf,
min(coupon_department) coup_dep,
coupon_type,
sum(households_red) hh_red,
sum(coup_qty) red_qty,
sum(redeem_value) red_val
FROM lcm_eval.lcm_compare_redeemed_cell r,
dim_campaign c
WHERE r.campaign_id = c.campaign_id
and c.campaign_code = '&LCMXXXX'
and r.cell_key in (41)
group
by coupon_upc,
coupon_type) r,
(SELECT /*+ use_hash(a b c) */
d.coupon_upc,
d.coup_desc,
d.manuf,d.coup_dep,
d.coupon_type,
sum(a.counts) coups_mailed,
sum(a.households) households_mailed
FROM lcm_eval.lcm_current_coupon_alloc_cell a,
dim_campaign c,
(SELECT distinct
coupon_upc,
min(coupon_description) coup_desc,
min(campaign_manufacturer_desc) manuf,
min(coupon_department) coup_dep,
coupon_type
FROM contact_coupon_details
WHERE schedule_key = '23'
group by coupon_upc,coupon_type) d
WHERE a.campaign_id = c.campaign_id
and c.campaign_code = '&LCMXXXX' code
and a.cell_key in (41)
and a.coupon_upc = d.coupon_upc
group by d.coupon_upc, d.coup_desc, d.manuf, d.coup_dep, d.coupon_type) a
WHERE a.coupon_upc = r.coupon_upc (+)
ORDER by a.coupon_type;
La colonne que j'ai besoin de résumer est (r.red_qty/a.households_mailed). Cela doit se faire par groupes de (cellkey, a.coupon_type). c'est-à-dire pour chaque combinaison de (cellkey, a.coupon_type) quelle est la valeur de (r.red_qty/a.households_mailed).Problème avec une requête complexe dans Oracle
Quelqu'un peut-il suggérer un seul SQL pour faire la même chose ou un bloc anonyme pour le même?
quelle version d'Oracle? (J'ai remarqué des jointures de style ancien se demandant si cela a la contrainte supplémentaire de 8i) – Harrison
Oracle 10g.Le code est un vieux. C'est à peu près tout. –