Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Mengira Jumlah Berjalan dengan Cekap dalam 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!