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!