Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Mengira Jumlah Berjalan dengan Cekap dalam MySQL?

Bagaimana untuk Mengira Jumlah Berjalan dengan Cekap dalam MySQL?

DDD
DDDasal
2025-01-22 06:26:08295semak imbas

How to Efficiently Calculate Running Totals in MySQL?

Jumlah berjalan MySQL: penyelesaian menggunakan pembolehubah pengguna

Artikel ini, asalnya bertajuk "Mengira jumlah berjalan dalam MySQL," bertujuan untuk menambah lajur pada jadual yang memaparkan jumlah kumulatif nilai lajur sebelumnya. Walau bagaimanapun, jawapan yang diberikan menyatakan bahawa penggunaan pembolehubah pengguna dalam ungkapan kini ditamatkan dan akan dialih keluar dalam versi akan datang. Oleh itu, kami menawarkan penyelesaian yang lebih mudah yang melibatkan memulakan jumlah pembolehubah yang sedang berjalan dan melaksanakan satu pertanyaan menggunakan pengiraan matematik untuk mencapai hasil yang diingini.

Pertanyaan yang diberikan adalah seperti berikut:

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

Pertanyaan ini mula-mula memulakan pembolehubah pengguna @runtot kepada 0 menggunakan pernyataan SET. Ia kemudian melaksanakan subkueri untuk mendapatkan semula data yang diperlukan daripada jadual pesanan. Akhir sekali, pertanyaan luar menggabungkan hasil subkueri dengan jumlah pengiraan yang sedang berjalan.

Jadual yang terhasil akan mengandungi lajur tambahan yang dipanggil rt yang mewakili jumlah berjalan untuk lajur c untuk setiap baris. Penyelesaian ini mengelakkan penggunaan pembolehubah pengguna yang ditamatkan dalam ungkapan dan menyediakan pendekatan yang lebih cekap dengan satu pelaksanaan pertanyaan.

Atas ialah kandungan terperinci Bagaimana untuk Mengira Jumlah Berjalan dengan Cekap dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn