Vous pouvez joindre votre table à elle-même :
select l1.id, avg( l2.Temperature )
from l l1
inner join l l2
on l2.id <= l1.id and
l2.Timestamps + interval '15 minutes' > l1.Timestamps
group by l1.id
order by id
;
Résultats :
| ID | AVG |
-----------------------
| 1 | 5.39 |
| 2 | 5.365 |
| 3 | 5.296666666667 |
| 4 | 5.3575 |
| 5 | 5.346 |
| 6 | 5.321666666667 |
| 7 | 5.331428571429 |
Avis :Seul le « travail acharné » est effectué. Vous devez joindre le résultat à la table d'origine ou ajouter de nouvelles colonnes à la requête. Je ne sais pas si votre dernière requête est nécessaire. Adaptez cette solution ou demandez plus d'aide.