Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Mengira dan Menghimpunkan Data Serentak dalam Pernyataan SQL Tunggal?
Menggabungkan COUNT dan GROUP BY untuk Pengagregatan Data yang Cekap
SQL menyediakan mekanisme yang berkuasa untuk melaksanakan kedua-dua operasi mengira dan mengumpulkan dalam satu pernyataan. Ini amat membantu apabila anda perlu menentukan kekerapan nilai yang berbeza dalam set data. Contohnya, mengira bilangan pengguna yang tinggal di pelbagai bandar.
Kuncinya ialah menggunakan COUNT
fungsi agregat bersama dengan klausa GROUP BY
. Begini cara anda boleh mencapai ini:
<code class="language-sql">SELECT town, COUNT(*) AS UserCount FROM user GROUP BY town;</code>
Pertanyaan ini mengira kejadian setiap nilai town
unik. Klausa GROUP BY
memastikan bahawa kiraan dikumpulkan mengikut bandar, menghasilkan ringkasan yang menunjukkan setiap bandar dan bilangan pengguna yang sepadan. Menggunakan COUNT(*)
adalah lebih cekap daripada COUNT(town)
dalam senario ini.
Output akan menjadi jadual dengan dua lajur: town
dan UserCount
, dengan UserCount
mewakili jumlah pengguna untuk setiap bandar. Sebagai contoh, dengan tiga bandar (Copenhagen, New York, Athens) dan sejumlah 58 pengguna, hasilnya mungkin kelihatan seperti ini:
Town | UserCount |
---|---|
Copenhagen | 20 |
New York | 20 |
Athens | 18 |
Sebagai alternatif, anda boleh menggunakan pembolehubah untuk menyimpan jumlah kiraan pengguna dan memasukkannya dalam set hasil:
<code class="language-sql">DECLARE @TotalUsers INT; SELECT @TotalUsers = COUNT(*) FROM user; SELECT DISTINCT town, @TotalUsers AS TotalUserCount FROM user;</code>
Pendekatan ini mengira jumlah pengguna dan kemudian memaparkan jumlah ini bersama setiap bandar dalam output. Ambil perhatian bahawa kaedah ini akan mengulangi jumlah kiraan pengguna untuk setiap bandar. Kaedah pertama biasanya lebih disukai untuk kejelasan dan kecekapan apabila memerlukan kiraan berkumpulan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengira dan Menghimpunkan Data Serentak dalam Pernyataan SQL Tunggal?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!