Taulu: (id, date, arvo)
Miten lasken jokaiselle taulun riville keskiarvon joka perustuu kyseisen rivin edeltävän ja sitä seuraavan arvojen keskiarvolle?
Eli rivin joka id = 6 keskiarvo lasketaan arvoista joiden id:t ovat 5 ja 7
Samoin rivin jonka id = 7 keskiarvo lasketaan arvoista joiden id:t ovat 6 ja 8
jne...
Onko mahdollista?
MySql ksyymys
1
99
Vastaukset
- -------
Niin alikyselyllähän toi onnistuu.
Huomioithan että ID kasvaa aina yhdellä, joten poiston jälkeen sieltä saattaa puuttua välistä joku numero. Joten tälläinen ei hyvä mitä meinasit
SELECT t.arvo, (SELECT AVG(arvo) FROM taulu WHERE t.id IN (5,7)) AS keskiarvo FROM taulu AS t WHERE t.id = 6
Joten tälläinen parempa
SELECT t.arvo, ((SELECT arvo FROM taulu WHERE id > t.id LIMIT 1) (SELECT arvo FROM taulu WHERE id < t.id LIMIT 1) / 2) AS keskiarvo FROM taulu AS t LIMIT 4
Idea on siis se, että haetaan pienempi ja suurempi id, ja lasketaan niiden arvoista keskiarvo.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Oletko kertonut jo muille tunteistasi?
Ystävillesi esimerkiksi? Minä en ole vielä kertonut kenellekään tästä meidän jutusta.774622- 1801897
- 1241600
- 1241125
Miten minusta tuntuu että kaikki tietää sun tunteista mua kohtaan
Paitsi suoraan minä itse, vai mitä hlvettiä täällä tapahtuu ja miksi ihmiset susta kyselee minulta 🤔❤️161081- 351036
- 78933
- 52896
Hyvää huomenta!
Mietin miten suhtaudut minuun, jos kerron tunteista. Voinko enää sen jälkeen olla samassa paikassa kanssasi, jos koet as78872- 4838