Я хочу выполнить запрос и получить строки, перебирая массив, используя цикл FOREACH в postgresql.
Я попытался использовать цикл FOREACH, как описано в документации, но он возвращает ошибку "невозможно использовать RETURN QUERY в функции без SETOF"
DO
$do$
DECLARE
a integer[] := array[1,2,3];
i integer;
begin
foreach i IN ARRAY a
LOOP
RETURN QUERY
select
models.sku,
(sum(models.unitretailprice) * sum(coefficients.unit_retail_price)) +
(sum(models.flag::int) * sum(coefficients.flag::int)) +
(sum(models.mc_baseline) * sum(coefficients.mc_baseline)) +
(sum(models.mc_day_avg) * sum(coefficients.mc_day_avg)) +
(sum(models.mc_day_normal) * sum(coefficients.mc_day_normal)) +
(sum(models.mc_week_avg) * sum(coefficients.mc_week_avg)) +
(sum(models.mc_week_normal) * sum(coefficients.mc_week_normal)) +
(sum(models.sku_day_avg) * sum(coefficients.sku_day_avg)) +
(sum(models.sku_month_avg) * sum(coefficients.sku_month_avg)) +
(sum(models.sku_month_normal)* sum(coefficients.sku_month_normal)) +
(sum(models.sku_moving_avg) * sum(coefficients.sku_moving_avg)) +
(sum(models.sku_week_avg) * sum(coefficients.sku_week_avg)) +
(sum(models.sku_week_normal)* sum(coefficients.sku_week_normal)) as baseline,
(i * sum(coefficients.f)) +
(5 * sum(coefficients.p)) +
(0 * sum(coefficients.a)) as promoIncremental,
(sum(models.basket_dollar_off) * sum(coefficients.basket_dollar_off)) +
(sum(models.basket_per_off) * sum(coefficients.basket_per_off)) +
(sum(models.category_dollar_off) * sum(coefficients.category_dollar_off)) +
(sum(models.category_per_off) * sum(coefficients.category_per_off)) +
(sum(models.disc_per) * sum(coefficients.disc_per)) as couponIncremnetal
from
models join coefficients
on
models.sku = coefficients.sku
and
models.si_type = coefficients.si_type
and
models.model_type = coefficients.model_type
where
coefficients.sku in ('12841276', '11873916') and coefficients.shop_descr = 'Papercrafting Technology'
group by models.sku ;
END LOOP;
конец
$ Сделать $