Forum: PC-Programmierung MySQL-Frage (Tabelle mit Geburtsdaten in Altersstruktur umwandeln)


von Skripter (Gast)


Lesenswert?

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.

von Name (Gast)


Lesenswert?

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.

von Peter (Gast)


Lesenswert?

> 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;

von Skripter (Gast)


Lesenswert?

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?

von Peter (Gast)


Lesenswert?

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
Noch kein Account? Hier anmelden.