Heim >Datenbank >MySQL-Tutorial >Wie kann ich SQL-Daten für die Berichterstellung nach Monat und Jahr gruppieren?

Wie kann ich SQL-Daten für die Berichterstellung nach Monat und Jahr gruppieren?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2025-01-05 12:10:43178Durchsuche

How Can I Group SQL Data by Month and Year for Reporting?

SQL-Daten nach Monat und Jahr gruppieren

In einer SQL-Abfrage ist es häufig erforderlich, Daten zur Analyse nach Monat und Jahr zu gruppieren. Dazu gehört das Erstellen einer neuen Spalte, die die gewünschte Gruppierungskombination darstellt.

Betrachten Sie die folgende Abfrage:

SELECT MONTH(date) AS Mjesec, SUM(marketingExpense) AS SumaMarketing, SUM(revenue) AS SumaZarada
FROM [Order]
WHERE (idCustomer = 1) AND (date BETWEEN '2001-11-3' AND '2011-11-3')
GROUP BY MONTH(date), YEAR(date)

Diese Abfrage gruppiert die Daten nach Monat, was zu einer Ausgabe wie „9“ für September führt . Um den Monat und das Jahr zusammen anzuzeigen, können wir die CAST-Funktion verwenden, um die Monats- und Jahreswerte in Zeichenfolgen umzuwandeln und sie mit einem Bindestrich zu verketten.

SELECT CAST(MONTH(date) AS VARCHAR(2)) + '-' + CAST(YEAR(date) AS VARCHAR(4)) AS Mjesec, SUM(marketingExpense) AS SumaMarketing, SUM(revenue) AS SumaZarada
FROM [Order]
WHERE (idCustomer = 1) AND (date BETWEEN '2001-11-3' AND '2011-11-3')
GROUP BY CAST(MONTH(date) AS VARCHAR(2)) + '-' + CAST(YEAR(date) AS VARCHAR(4))

Diese Änderung zeigt die Ergebnisse im gewünschten Format an. zum Beispiel „9-2011“.

Alternativ können wir die CAST-Funktion mit führenden Nullen verwenden, um die Konsistenz sicherzustellen Formatierung:

GROUP BY
  CAST(YEAR(date) AS VARCHAR(4)) + '-' + right('00' + CAST(MONTH(date) AS VARCHAR(2)), 2)

Dies führt zu einer Ausgabe wie „2011-09“.

Das obige ist der detaillierte Inhalt vonWie kann ich SQL-Daten für die Berichterstellung nach Monat und Jahr gruppieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn