Bagaimana untuk Mendapatkan Baris Berdasarkan Jumlah Nilai Terdahulu Menggunakan Fungsi SUM() MySQL?

Susan Sarandon
Lepaskan: 2024-11-04 16:00:03
asal
348 orang telah melayarinya

How to Retrieve a Row Based on the Sum of Previous Values Using MySQL's SUM() Function?

Menggunakan Fungsi MySQL SUM() di WHERE Klausa untuk Pengambilan Baris

MySQL membenarkan pengguna melakukan pengiraan agregat dalam subkueri dan menggunakannya sebagai kriteria untuk pemilihan baris dalam klausa WHERE. Walau bagaimanapun, adalah penting untuk memahami had penggunaan fungsi agregat dalam konteks ini.

Pertimbangkan senario berikut: anda mempunyai jadual dengan id lajur dan wang tunai, dan anda ingin mendapatkan semula baris pertama dengan jumlah daripada semua nilai tunai sebelumnya melebihi ambang tertentu.

Contoh Jadual:

id cash
1 200
2 301
3 101
4 700

Keputusan yang Diingini:

Untuk ambang input 500, hasil yang dijangkakan ialah baris 3 kerana jumlah nilai tunai untuk baris 1 dan 2 (200 301 = 501) melebihi ambang.

Pendekatan Salah:

Percubaan untuk menggunakan WHERE SUM(tunai) > 500 tidak akan menghasilkan hasil yang betul kerana agregat tidak boleh dibandingkan secara langsung dalam klausa WHERE.

Penyelesaian:

Untuk mengatasi had ini, anda boleh menggunakan klausa HAVING dalam bersempena dengan subkueri untuk mengira jumlah wang tunai yang dijalankan bagi setiap baris.

<code class="sql">SELECT y.id, y.cash
FROM (
    SELECT t.id,
           t.cash,
           (SELECT SUM(x.cash)
              FROM TABLE x
             WHERE x.id <= t.id) AS running_total
     FROM TABLE t
     ORDER BY t.id
) y
WHERE y.running_total > 500
ORDER BY y.id
LIMIT 1;</code>
Salin selepas log masuk

Penjelasan:

  1. Subkueri mengira jumlah tunai yang dijalankan untuk setiap baris menggunakan pernyataan SELECT bersarang.
  2. Hasil subkueri dialiaskan sebagai y.
  3. Klausa WHERE menyemak sama ada jumlah larian untuk baris melebihi ambang yang dikehendaki (500 dalam kes ini ).
  4. Akhir sekali, klausa LIMIT hanya mengambil baris pertama yang layak.

Pendekatan ini memastikan baris pertama di mana jumlah semua nilai tunai sebelumnya melebihi ambang dikenal pasti dengan tepat .

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Baris Berdasarkan Jumlah Nilai Terdahulu Menggunakan Fungsi SUM() MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan