首頁 > 資料庫 > mysql教程 > 如何使用 DENSE_RANK() 在 SQL 中取得不同的行號?

如何使用 DENSE_RANK() 在 SQL 中取得不同的行號?

DDD
發布: 2025-01-01 11:43:10
原創
750 人瀏覽過

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

使用DENSE_RANK() 取得不同行號的SQL 查詢

在SQL 中,尋找唯一(不同)值通常使用DISTINCT 來完成關鍵字。但是,當您需要顯示這些不同值的行號時,單獨使用 DISTINCT 可能不夠。

在給定的程式碼中:

SELECT DISTINCT id, ROW_NUMBER() OVER (ORDER BY id) AS RowNum
FROM table
WHERE fid = 64
登入後複製

DISTINCT 關鍵字刪除重複的 id 值,但是ROW_NUMBER() 函數為結果集中的每筆記錄分配一個唯一的行號。因此,它對於識別不同的值沒有用。

為了獲得所需的結果,我們可以使用DENSE_RANK() 函數代替:

SELECT DISTINCT id, DENSE_RANK() OVER (ORDER BY id) AS RowNum
FROM table
WHERE fid = 64
登入後複製

DENSE_RANK() 函數分配不同的排名每個唯一的id 值,忽略行號中的任何間隙。這為結果集中的不同值提供了唯一的行號。

以上是如何使用 DENSE_RANK() 在 SQL 中取得不同的行號?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板