Bagaimana Mengenalpasti Nilai Maksimum N Teratas dalam MySQL dengan Cekap?

DDD
Lepaskan: 2024-11-12 05:40:01
asal
830 orang telah melayarinya

How to Efficiently Identify the Top N Maximum Values in MySQL?

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
Salin selepas log masuk

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
Salin selepas log masuk

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
Salin selepas log masuk

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)
Salin selepas log masuk

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!

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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan