Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Mendapatkan Nombor Baris Berbeza dalam SQL Menggunakan DENSE_RANK()?

Bagaimana untuk Mendapatkan Nombor Baris Berbeza dalam SQL Menggunakan DENSE_RANK()?

DDD
Lepaskan: 2025-01-01 11:43:10
asal
702 orang telah melayarinya

How to Get Distinct Row Numbers in SQL Using DENSE_RANK()?

Pertanyaan SQL untuk Mendapatkan Nombor Baris Berbeza dengan DENSE_RANK()

Dalam SQL, mencari nilai unik (berbeza) biasanya dilakukan menggunakan DISTINCT kata kunci. Walau bagaimanapun, apabila anda perlu memaparkan nombor baris untuk nilai yang berbeza ini, menggunakan DISTINCT sahaja mungkin tidak mencukupi.

Dalam kod yang diberikan:

SELECT DISTINCT id, ROW_NUMBER() OVER (ORDER BY id) AS RowNum
FROM table
WHERE fid = 64
Salin selepas log masuk

Kata kunci DISTINCT mengalih keluar nilai id pendua, tetapi fungsi ROW_NUMBER() memberikan nombor baris unik kepada setiap rekod dalam set hasil. Jadi, ia tidak berguna untuk mengenal pasti nilai yang berbeza.

Untuk mencapai hasil yang diingini, kita boleh menggunakan fungsi DENSE_RANK() sebaliknya:

SELECT DISTINCT id, DENSE_RANK() OVER (ORDER BY id) AS RowNum
FROM table
WHERE fid = 64
Salin selepas log masuk

Fungsi DENSE_RANK() memberikan kedudukan yang berbeza kepada setiap nilai id unik, tanpa mengambil kira sebarang jurang dalam nombor baris. Ini memberikan nombor baris unik untuk nilai yang berbeza dalam set hasil.

Atas ialah kandungan terperinci Bagaimana untuk Mendapatkan Nombor Baris Berbeza dalam SQL Menggunakan DENSE_RANK()?. 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