Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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

Group by über eine Datumsspalte (MSSQL) Edit MYSQL SQLite

Anleitung Entwicklung Datenbanken

Mitglied: ChrFriedel

ChrFriedel (Level 1) - Jetzt verbinden

21.04.2010, aktualisiert 22.04.2010, 9888 Aufrufe, 4 Kommentare

Hallo an alle,

weil ich gerade selber darüber gestolpert bin und man es vielleicht gelegentlich mal brauchen kann hier meine Lösung um ein Group BY über eine Datumsspalte zu machen. Muss natürlich nicht die beste sein aber für mich funktioniert sie.

Angenommen man hat eine Tabelle mit den 2 Spalten ID und Datum. Das Datum ist in der Form YYYY-MM-DD HH:MM:SS gespeichert. Ein simples Group By für die einzelnen Tage funktioniert durch die abweichenden Zeiten dadurch nicht. Mit folgendem Statement lässt sich das Trotzdem realisieren.

01.
 
02.
SELECT CONVERT(CHAR(12), [Datum], 106)  AS Datum,  
03.
       Count([ID]) AS Anzahl  
04.
 
05.
FROM Tabelle  
06.
 
07.
GROUP BY DATEPART(yy, [Datum]), 
08.
         DATEPART(dy, [Datum]), 
09.
         CONVERT(CHAR(12), [Datum], 106)  
10.
 
11.
ORDER BY DATEPART(yy, [Datum]) desc,  
12.
         DATEPART(dy, [Datum]) desc 
13.
 
Die Ausgabe wäre dann soetwas wie:

Datum | Anzahl
21 Apr 2010 | 42
16 Apr 2010 | 130
...
Mitglied: nxclass
21.04.2010 um 23:14 Uhr
01.
SELECT 
02.
  DATE_FORMAT(`Datum`, '%d %b %Y') AS 'Datum', 
03.
  COUNT(`Id`) AS 'Anzahl' 
04.
FROM `Tabelle` 
05.
GROUP BY DATE(`Datum`) 
06.
ORDER BY `Datum` DESC;
Edit: http://dev.mysql.com/doc/refman/5.1/en/date-and-time-functions.html
Bitte warten ..
Mitglied: ChrFriedel
22.04.2010 um 09:33 Uhr
Ich vermute jetzt mal das ist das gleiche in MySQL oder?
Bitte warten ..
Mitglied: nxclass
22.04.2010 um 11:27 Uhr
... richtig - und ...
01.
SELECT 
02.
  strftime('%d %b %Y', `Datum`) AS 'Datum', 
03.
  count(´Id`) AS 'Anzahl' 
04.
FROM `Table` 
05.
GROUP BY date(`Datum`) 
06.
ORDER BY `Datum` DESC;
... sollte für SQLite funktionieren.
Bitte warten ..
Mitglied: ChrFriedel
22.04.2010 um 11:38 Uhr
Sieht irgendwie alles logischer aus als bei MSSQL.... aber man kann sichs ja nicht immer aussuchen ;)
Bitte warten ..
Ähnliche Inhalte
Datenbanken
gelöst SQL ORDER BY und Join mit 2 Tabellen (7)

Frage von Dipps zum Thema Datenbanken ...

Datenbanken
gelöst MSSQL Datenkonvertierung 1 Zeile auf mehrere Zeilen - bitte um Tips (4)

Frage von highmoe zum Thema Datenbanken ...

Microsoft
gelöst Fehler beim Ausführen eines MSSQL-Triggers mit EXECUTE AS User (1)

Frage von Mesaou zum Thema Microsoft ...

Datenbanken
MSSQL Management Studio Generiere Skript automatisieren (2)

Frage von 115122 zum Thema Datenbanken ...

Neue Wissensbeiträge
Google Android

Cyanogenmod alternative Downloadquelle

(2)

Tipp von Lochkartenstanzer zum Thema Google Android ...

Batch & Shell

Batch als Dienst bei Systemstart ohne Anmeldung ausführen

(5)

Tipp von tralveller zum Thema Batch & Shell ...

Sicherheits-Tools

Sicherheitstest von Passwörtern für ganze DB-Tabellen

(1)

Tipp von gdconsult zum Thema Sicherheits-Tools ...

Heiß diskutierte Inhalte
Windows 7
gelöst Lokales Adminprofil defekt (25)

Frage von Yannosch zum Thema Windows 7 ...

Server
gelöst Wie erkennen, dass nur deutsche IPs Zugang zu einer Website haben? (22)

Frage von Coreknabe zum Thema Server ...

LAN, WAN, Wireless
gelöst Statische Routen mit ISC-DHCP Server für Android Devices (22)

Frage von terminator zum Thema LAN, WAN, Wireless ...

Exchange Server
gelöst Migration Exchange 2007 zu 2013 - Public Folder teilweise weg (16)

Frage von Andy1987 zum Thema Exchange Server ...