Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mendapatkan Baris N Teratas bagi setiap Kumpulan dalam SQL?

Bagaimana untuk Mendapatkan Baris N Teratas bagi setiap Kumpulan dalam SQL?

Linda Hamilton
Lepaskan: 2025-01-25 12:07:09
asal
933 orang telah melayarinya

How to Get the Top N Rows per Group in SQL?

Petua SQL: Dapatkan N baris pertama data mengikut kumpulan

Artikel ini memperkenalkan cara mengekstrak N baris pertama data dengan cekap untuk setiap kumpulan daripada pangkalan data SQL. Kami akan menggunakan fungsi tetingkap seperti ROW_NUMBER(), RANK(), dan DENSE_RANK() untuk mencapai ini. Fungsi ini menjana pengecam unik dalam partition tertentu dan sesuai untuk pemilihan kumpulan dan baris.

Gunakan ROW_NUMBER()

Fungsi

ROW_NUMBER() memberikan nombor siri berturut-turut bermula dari 1 hingga baris dalam setiap partition.

SELECT *, ROW_NUMBER() OVER (PARTITION BY id ORDER BY rate DESC) AS rn
FROM h
WHERE year BETWEEN 2000 AND 2009
Salin selepas log masuk

Dalam contoh ini, ROW_NUMBER() mencipta lajur baharu bernama "rn" untuk memberikan nombor siri kepada baris dalam setiap kumpulan id.

Gunakan RANK() dan DENSE_RANK()

Fungsi

RANK() dan DENSE_RANK() menyediakan cara lain untuk menomborkan baris dalam kumpulan. RANK() memberikan nilai yang berbeza kepada baris dengan pengisihan yang sama, manakala DENSE_RANK() memberikan nilai berturut-turut.

SELECT *, RANK() OVER (PARTITION BY id ORDER BY rate DESC) AS rk,
DENSE_RANK() OVER (PARTITION BY id ORDER BY rate DESC) AS dr
FROM h
WHERE year BETWEEN 2000 AND 2009
Salin selepas log masuk

RANK() dan DENSE_RANK() mencipta lajur "rk" dan "dr" masing-masing, mewakili kedudukan setiap baris dan kedudukan padat dalam kumpulan idnya.

Digabungkan dengan LIMIT atau TOP untuk mengehadkan keputusan

Selepas memberikan pengecam unik kepada setiap kumpulan, anda boleh menggunakan LIMIT atau TOP pengubah suai untuk mendapatkan hanya bilangan baris yang ditentukan bagi setiap kumpulan.

SELECT *
FROM h
WHERE year BETWEEN 2000 AND 2009
ORDER BY id, rate DESC
LIMIT 5
Salin selepas log masuk

Dalam contoh ini, pengubah suai LIMIT mendapatkan semula 5 baris pertama setiap kumpulan id. Anda boleh melaraskan nombor mengikut keperluan.

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Baris N Teratas bagi setiap Kumpulan dalam SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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