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
112
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
- 1275735
Mikä on vaikeinta siinä, että menetti yhteyden kaivattuun, jota vielä ajattelee?
Mikä jäi kaihertamaan? Jos jokin olisi voinut mennä toisin, mitä se olisi ollut? Mitä olisit toivonut vielä ehtiväsi san3962549- 1342467
Persut rahoittavat velkarahalla rikkaiden ökyelämää
Minkä vuoksi persut eivät leikkaa rikkailta, joilla on maksukykyä? Tuskinpa tuo persujen käytös saa Suomen kansalta hyv52053- 121293
- 581045
Kun ei numeroa
niin en edes voi viestittää, et suunnitelmiin tuli muutos. Ikävä on, ja kasvaa vaan🤍81032- 51902
- 76815
Temusta tilaamiseen tulee muutos
Alle 150 euron tullivapaus poistuu. Vihdoinkin kankea EU saa jotakin aikaiseksi. https://www.iltalehti.fi/digiuutiset/101805