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
102
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
Ensi kesänä
Näin kesän viimeisenä minuutteina ajattelen sinua. Olisiko seuraava kesä "meidän" kesä? Tänä vuonna ei onnistuttu, mutta643315Tukalaa kuumuutta
Tietäisitpä vaan kuinka kuumana olen käynyt viime päivät. Eikä johdu helteestä, vaan sinusta. Mitäköhän taikoja olet teh433127- 432508
Anne Kukkohovin karmeat velat ovat Suomessa.
Lähtikö se siksi pois Suomesta ? Et on noin kar? mean suuret velat naisella olemassa1112406- 311933
Okei, myönnetään,
Oisit sä saanut ottaa ne housutkin pois, mutta ehkä joskus jossain toisaalla. 😘271820- 481626
Mihin hävisi
Mihin hävisi asiallinen keskustelu tositapahtumista, vai pitikö jonkin Hannulle kateellisen näyttää typeryytensä851435- 391300
- 821169