Mengenal pasti Nilai N Maks Teratas dalam MySQL
Dalam banyak senario, membuat pertanyaan untuk baris N teratas dengan nilai tertinggi dalam lajur tertentu adalah penting. Walau bagaimanapun, mungkin terdapat kekeliruan mengenai cara mengendalikan kes di mana berbilang baris berkongsi nilai maksimum yang sama dan sama ada untuk memasukkan semua baris dengan nilai yang sama atau hanya N atas.
Untuk menangani isu ini, anda boleh menggunakan kaedah berikut:
Pilihan 1: Tepat Atas N
Menggunakan klausa LIMIT, anda boleh mendapatkan semula baris N atas tepat dalam susunan menurun mengikut nilai, tidak termasuk mana-mana baris dengan nilai yang sama:
SELECT * FROM t ORDER BY value DESC LIMIT N
Pilihan 2: N Teratas Inklusif
Jika anda ingin memasukkan semua baris dengan nilai maksimum yang sama, walaupun terdapat lebih daripada N baris dengan nilai itu, anda boleh menggunakan pendekatan berikut:
Sertai jadual dengan subkueri yang mencari nilai potong minimum untuk N teratas:
SELECT * FROM t JOIN ( SELECT MIN(value) AS cutoff FROM ( SELECT value FROM t ORDER BY value LIMIT N ) tlim ) tlim ON t.value >= tlim.cutoff
Sebagai alternatif, anda boleh menggunakan versi yang dipermudahkan:
SELECT * FROM t JOIN ( SELECT value FROM t ORDER BY value LIMIT N ) tlim ON t.value = tlim.value
Alternatif Konseptual (Pilihan)
Walaupun pertanyaan berikut secara konseptual menangkap gelagat yang diingini, ia mungkin tidak berfungsi dalam MySQL:
SELECT * FROM t WHERE t.value >= ANY (SELECT value FROM t ORDER BY value LIMIT N)
Atas ialah kandungan terperinci Bagaimana Mengenalpasti Nilai Maksimum N Teratas dalam MySQL dengan Cekap?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!