mikrocontroller.net

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


Autor: Skripter (Gast)
Datum:

Bewertung
0 lesenswert
nicht 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.

Autor: Name (Gast)
Datum:

Bewertung
0 lesenswert
nicht 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.

Autor: Peter (Gast)
Datum:

Bewertung
0 lesenswert
nicht 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;

Autor: Skripter (Gast)
Datum:

Bewertung
0 lesenswert
nicht lesenswert
Geburtsdatum ist als DATE gespeichert. Erschien mir sinnvoll.
SELECT
  date_format( geburtsdatum, "%Y" ) AS jahr,
  count( * )
FROM
  mitglied
GROUP BY
  jahr
ORDER BY
  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?

Autor: Peter (Gast)
Datum:

Bewertung
0 lesenswert
nicht 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

Antwort schreiben

Die Angabe einer E-Mail-Adresse ist freiwillig. Wenn Sie automatisch per E-Mail über Antworten auf Ihren Beitrag informiert werden möchten, melden Sie sich bitte an.

Wichtige Regeln - erst lesen, dann posten!

  • Groß- und Kleinschreibung verwenden
  • Längeren Sourcecode nicht im Text einfügen, sondern als Dateianhang

Formatierung (mehr Informationen...)

  • [c]C-Code[/c]
  • [avrasm]AVR-Assembler-Code[/avrasm]
  • [code]Code in anderen Sprachen, ASCII-Zeichnungen[/code]
  • [math]Formel in LaTeX-Syntax[/math]
  • [[Titel]] - Link zu Artikel
  • Verweis auf anderen Beitrag einfügen: Rechtsklick auf Beitragstitel,
    "Adresse kopieren", und in den Text einfügen




Bild automatisch verkleinern, falls nötig
Bitte das JPG-Format nur für Fotos und Scans verwenden!
Zeichnungen und Screenshots im PNG- oder
GIF-Format hochladen. Siehe Bildformate.
Hinweis: der ursprüngliche Beitrag ist mehr als 6 Monate alt.
Bitte hier nur auf die ursprüngliche Frage antworten,
für neue Fragen einen neuen Beitrag erstellen.

Mit dem Abschicken bestätigst du, die Nutzungsbedingungen anzuerkennen.