Heim >Datenbank >MySQL-Tutorial >Wie berechnet man laufende Summen in MySQL mit einer einzigen Abfrage?

Wie berechnet man laufende Summen in MySQL mit einer einzigen Abfrage?

Linda Hamilton
Linda HamiltonOriginal
2025-01-22 06:46:10567Durchsuche

How to Calculate Running Totals in MySQL with a Single Query?

Effiziente Berechnung laufender Summen in MySQL mit einer einzigen Abfrage

Diese Anleitung zeigt eine einzelne MySQL-Abfrage zur Berechnung der laufenden Gesamtsummen für die Anzahl der täglichen Bestellungen, vorausgesetzt, Ihre Daten enthalten eine date-Spalte und ein hasPaid-Flag, das eine erfolgreiche Zahlung anzeigt.

Hier ist die optimierte Abfrage:

<code class="language-sql">SET @runtot:=0;
SELECT
   DATE(`date`) AS d,
   COUNT(*) AS c,
   (@runtot := @runtot + COUNT(*)) AS rt
FROM  `orders`
WHERE  `hasPaid` > 0
GROUP  BY d
ORDER  BY d;</code>

Diese Abfrage initialisiert eine Variable @runtot auf Null. Die Kernlogik berechnet dann die tägliche Bestellanzahl (COUNT(*) AS c) und aktualisiert gleichzeitig die laufende Gesamtsumme (@runtot := @runtot COUNT(*) AS rt) in einer einzigen SELECT-Anweisung. Dadurch werden Unterabfragen oder mehrere Durchgänge vermieden, was zu einer verbesserten Effizienz führt. Die GROUP BY d-Klausel gruppiert die Ergebnisse nach Tag und ORDER BY d stellt sicher, dass die laufende Summe sequentiell berechnet wird. Diese Methode generiert effizient die laufende Gesamtspalte (rt) neben der täglichen Bestellanzahl (c) und dem Tag (d).

Das obige ist der detaillierte Inhalt vonWie berechnet man laufende Summen in MySQL mit einer einzigen Abfrage?. 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