Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

MySQL Abfrage für demographische Zwecke

Frage Entwicklung Datenbanken

Mitglied: morphil

morphil (Level 1) - Jetzt verbinden

18.05.2017 um 15:50 Uhr, 302 Aufrufe, 3 Kommentare

Hallo

Ich habe folgende Mitglieder-Tabelle in einer MariaDB mit ca. 10.000 Einträgen.

ID Geburtsdatum Eintrittsdatum Austrittsdatum
1 05.07.1990 01.01.2010 05.07.2016
2 06.06.1980 01.04.2000
3 01.04.2000 06.10.2010 01.05.2017

Ist das Austrittsdatum leer (NULL) ist dieses Mitglied noch "aktiv".

Ziel der Abfrage ist es nun den demographischen Wandel der letzten 10 Jahre in der Organisation auszuwerten. Die letzten 10 Jahre dem Alter (hier verdichtet in 3 Altersklassen) gegenübergestellt, mit der jeweiligen Anzahl an Mitgliedern per Stichtag am 1.1 des jeweiligen Jahres.

Das Ergebnisse sollte ungefähr so aussehen:

Alter 2017 2016 2014 2013 2012 usw.
0-16 101 102 103 104 105
17-59 1010 1020 1030 1040 1050
60+ 301 302 303 304 305

Leider fehlt mir momentan komplett der Ansatz, zum einem brauche ich das Alter in Relation zum jeweiligen Jahr und zu anderen sollten nur Mitglieder gezählt werden die in diesem Jahr auch aktiv waren (zwischen Eintritts und Austrittsdatum sofern vorhanden)



Mitglied: ukulele-7
19.05.2017 um 08:31 Uhr
Ich hab das jetzt nicht getestet aber in etwa so würde ich vorgehen:
01.
SELECT	datepart(year,hilfstabelle.stichtag) AS jahr, 
02.
		(	CASE 
03.
			WHEN	datediff(year,t.geburtsdatum,hilfstabelle.stichtag) BETWEEN 0 AND 16 
04.
			THEN	'0-16' 
05.
			WHEN	datediff(year,t.geburtsdatum,hilfstabelle.stichtag) BETWEEN 17 AND 59 
06.
			THEN	'17-59' 
07.
			WHEN	datediff(year,t.geburtsdatum,hilfstabelle.stichtag) >= 60 
08.
			THEN	'60+' 
09.
			ELSE	'Fehler' 
10.
			END ) AS 'Alter', 
11.
		count(*) AS anzahl 
12.
FROM	( 
13.
 
14.
SELECT cast('2012-01-01' AS DATE) AS stichtag UNION ALL 
15.
SELECT '2013-01-01' UNION ALL 
16.
SELECT '2014-01-01' UNION ALL 
17.
SELECT '2015-01-01' UNION ALL 
18.
SELECT '2016-01-01' UNION ALL 
19.
SELECT '2017-01-01' 
20.
 
21.
		) hilfstabelle 
22.
INNER JOIN tabelle t 
23.
ON		hilfstabelle.stichtag BETWEEN t.eintritt AND isnull(t.austritt,'9999-12-31') 
24.
GROUP BY 1,2 
25.
ORDER BY 1,2
Erst brauchst du eine Hilfstabelle mit allen Stichtagen, ich hab das jetzt recht plump gemacht zumal MySQL viele Dinge nicht kann und ich da unsicher bin. Dann der Join und gruppieren und du hast alles in 3 Spalten. Im Nachgang könnte man das jetzt noch mit PIVOT in die von dir gezeigte Form bringen aber ich mag PIVOT nicht daher überlasse ich das dir. (Auch hier geht es leider nur unter fester Angabe aller Jahreszahlen wenn ich mich nicht irre.)
Bitte warten ..
Mitglied: morphil
19.05.2017 um 09:57 Uhr
datepart und isnull gibt es bei mysql nicht als funktion und datediff sehen die Argumente anders aus.

Zum Testen kann ich eine Hilfstabelle anlegen, auf die produktive DB habe ich nur Lesezugriff, also eigenen Views, Funktionen, Hilfstabellen,.. geht schlecht.

Aber zumindest den Ansatz habe ich verstanden.
Es würde mir auch reichen, wenn ich nicht gleich in einem Schritt in 3 Klassen einteile, sondern nur mal das Alter (bezogen auf den Stichjahr) mit der Anzahl der Mitglieder.
Bitte warten ..
Mitglied: ukulele-7
LÖSUNG 19.05.2017 um 10:53 Uhr
Also die Hilfstabelle ist in meiner Variante fest im Select gegeben, das könntest du zumindest zum Testen erstmal nutzen. Ob sich das später eleganter Lösen läßt muss man dann sehen.

Die Funktionen sind aus MSSQL, sry habe ich vergessen zu erwähnen. Die gibt es aber alle auch in MySQL mit etwas anderer Syntax. Bei datediff() in Verbindung mit Jahr muss man noch aufpassen, es wird kaufmännisch gerundet. Das ändert aber erstmal nichts am Ansatz.
Bitte warten ..
Ähnliche Inhalte
Datenbanken
MYSQL Abfrage
gelöst Frage von datadexxDatenbanken20 Kommentare

Halo an alle MySQL Spezialisten! Wie kann ich denn am besten folgende Werte abfragen und berechnen? Ausgang für die ...

PHP
Suchfeld mit Abfrage auf eine MySQL-Datenbank
gelöst Frage von SaschaRDPHP6 Kommentare

Hallo zusammen, ich steh mal wieder auf dem Schlauch. Bin dabei ein Suchfeld auf die Webseite zu bringen. Jedoch ...

Datenbanken
MySQL Abfrage für eine Umsatzauswertung kombinieren
gelöst Frage von RedBullmachtfitDatenbanken2 Kommentare

Hallo zusammen, ich möchte Kundenumsätze aus einer MySQL (v5.6, Windows) Datenbank ziehen. Ich komme mit der Struktur jedoch nicht ...

PHP
PHP MySQL Abfrage aus Datenbank
Frage von Lost144PHP12 Kommentare

Hallo, Ich habe in einer Datenbank daten über VM's stehen. Angaben wie hostname,adresse, serverat usw. Wie kann ich in ...

Neue Wissensbeiträge
Humor (lol)

"gimme gimme gimme": Automatischer Test stolpert über Easter Egg im man-Tool

Information von Penny.Cilin vor 1 StundeHumor (lol)2 Kommentare

Interessant, was man so alles als Easter Egg implementiert. Ist schon wieder Ostern? "gimme gimme gimme": Automatischer Test stolpert ...

MikroTik RouterOS

Mikrotik - Lets Encrypt Zertifikate mit MetaROUTER Instanz auf dem Router erzeugen

Anleitung von colinardo vor 16 StundenMikroTik RouterOS8 Kommentare

Einleitung Folgende Anleitung ist aus der Lage heraus entstanden das ein Kunde auf seinem Mikrotik sein Hotspot Captive Portal ...

Sicherheit

Sicherheitslücke in HP-Druckern - Firmware-Updates stehen bereit

Information von BassFishFox vor 17 StundenSicherheit1 Kommentar

Ein weiterer Grund, dass Drucker keinerlei Verbindung nach "auswaerts" haben sollen. Unter Verwendung spezieller Malware können Angreifer aus der ...

Administrator.de Feedback

Entwicklertagebuch: Die Startseite wurde überarbeitet

Information von admtech vor 19 StundenAdministrator.de Feedback10 Kommentare

Hallo Administrator User, mit dem Release 5.7 haben wir unsere Startseite überarbeitet und die Beiträge und Fragen voneinander getrennt. ...

Heiß diskutierte Inhalte
Windows Server
RDP macht Server schneller???
Frage von JaniDJWindows Server17 Kommentare

Hallo Community, wir betrieben seit geraumer Zeit diverse virtuelle Maschinen und Server mit Windows Server 2012. Leider haben wir ...

Windows Netzwerk
Netzwerk Neustrukturierung
Frage von IT-DreamerWindows Netzwerk16 Kommentare

Hallo verehrte Community und Admins, bei uns im Haus steht eine Neustrukturierung an. Dafür benötige ich von euch ein ...

Windows 10
Windows 10 dunkler Bildschirm nach Umfallen
Frage von AkcentWindows 1015 Kommentare

Hallo, habe hier einen Windows 10 Rechner der von einem User umgefallen wurde (Beine übers Knie, an den PC ...

Linux
OpenSource Groupware
Frage von FA-jkaLinux13 Kommentare

Hallo, ich suche eine Groupware als Alternative zum Exchange. Wesentliche Aufgaben sind die Handhabung von E-Mails (persönliche und gemeinsam ...