select
"date",
shop_id,
amount,
extract(dow from date),
case when
row_number() over (order by date) > 3
then
avg(amount) OVER (
ORDER BY date DESC
ROWS BETWEEN 1 following AND 3 FOLLOWING
)
else null end
from (
select *
from ro
where extract(dow from date) = 4
) s
ओपी की क्वेरी में क्या गलत है वह है फ्रेम विनिर्देश:
ROWS BETWEEN 0 PRECEDING AND 2 FOLLOWING
इसके अलावा मेरी क्वेरी महंगे विंडो फ़ंक्शंस को लागू करने से पहले गुरुवार को फ़िल्टर करके अनावश्यक कंप्यूटिंग से बचाती है।
यदि shop_id द्वारा विभाजन करना आवश्यक है तो स्पष्ट रूप से partition by shop_id
जोड़ें दोनों कार्यों के लिए, avg
और row_number
।