Hallo, ich habe eine Tabelle in MySQL: Name, Vorname, Geburtsdatum, ... Was ich gerne hätte, ist eine Art Alterspyramide. Also eine Liste, die angibt, welche Alter vertreten sind und wieviele Personen jeweils dieses Alter haben. Das ganze sollte möglichst, wenn das geht, mit einer einzigen MySQL-Abfrage entstehen. Kann mir da jemand helfen? Ich bin noch nicht so fit in MySQL.
1 | select jahr, count(*) from TABELLE group by jahr order by jahr asc; |
Falls das Geburtsdatum ungeschickterweise als DATE oder DATETIME gespeichert ist, dann selbiges vorher auseinanderpfriemeln, schlimmstenfalls in eine temporäre Tabelle.
> select jahr, count(*) from TABELLE group by jahr order by jahr asc; > Falls das Geburtsdatum ungeschickterweise als DATE oder DATETIME > gespeichert ist, dann selbiges vorher auseinanderpfriemeln, > schlimmstenfalls in eine temporäre Tabelle. der anfang ist ja schon mal gut, aber das mit der tmp tabelle ist unsinn, dafür gibt es ja funktionen select year(GebDatum), count(*) from TABELLE group by year(GebDatum) order by year(GebDatum) asc;
Geburtsdatum ist als DATE gespeichert. Erschien mir sinnvoll.
1 | SELECT |
2 | date_format( geburtsdatum, "%Y" ) AS jahr, |
3 | count( * ) |
4 | FROM |
5 | mitglied |
6 | GROUP BY |
7 | jahr |
8 | ORDER BY |
9 | jahr ASC |
funktioniert schonmal, danke! Jetzt hätte ich nur gerne statt Geburtsjahr das Alter in Jahren, am liebsten mit Berücksichtigung, ob der betreffende im aktuellen Jahr schon Geburtstag hatte oder nicht. Könntest du da weiterhelfen?
suche mal in der doku die DateDiff funktion, ich kann es bloss vom sql-Server auswendig SELECT datediff( year, now(), gebdatum ), count( * ) FROM mitglied GROUP BY datediff( year, now(), gebdatum ) ORDER BY datediff( year, now(), gebdatum ) ASC
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.