Mysql如何查詢某條記錄在分頁的第幾頁詳析

查詢是我們日常工作中經常會遇到的一個功能,下面這篇文章主要給大家介紹了關於Mysql如何查詢某條記錄在分頁的第幾頁的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下

前言

在實踐中我們會遇到這樣的問題,知道某條記錄的id,然後需要判斷此條記錄如果按照id進行排序分頁,此條記錄在第幾頁。今天這篇文章爲大家提供一個思路。

下面話不多說了,來一起看看詳細的實現方法吧

根據ID查詢分頁位置

根據ID來查詢分頁位置,比如按照ID的倒序排列,則可通過以下SQL查詢出大於此ID記錄數:

select count(id) from user where id > 5;

示例中user爲表名,5位待匹配的id。很顯然,因爲是倒序排序只需查找大於此id的記錄數即可,如果是正序排列,則小於此id即可。

當查出count值之後,怎麼計算當前記錄位於第幾頁呢,這裏以java代碼示例計算:

int pageSize = 10;
// 假設上面查出的結果爲count,值爲11
int count = 11;
// 計算當前記錄所在的pageNum
// 通過取模並加1獲得當前頁數爲第2頁
int pageNum = count/pageSize + 1;
// 如果想進一步獲得在某頁的某個位置,則再進行取餘即可,即第2頁的第1條記錄(從0開始)
int index = count%pageSize;

多維度排序定位

上面通過簡單的ID進行排序還是比較好解決的,那麼如果現在查詢某條記錄排序的維度不僅僅是ID,比如先按照年齡(age)進行倒序排序,如果age相同,則再跟進ID進行倒序排序。基本的sql語句如下:

select id, age from user order by age desc,id desc;

此時我們知道某條id爲5,age爲18的記錄,如何確定出此條記錄在多條件排序中的位置呢。

首先,多條件排序的難度在於age相同的情況,如果age不相同,只需如下sql即可像《根據ID查詢分頁位置》一樣定位出id的位置:

select count(id) from user where age > 18;

這樣就可以查詢出來此組合排序age不相同時此條記錄的位置,具體位置的算法同第一種情況。

那麼當age用重複的情況如何處理呢。當然,可以通過複雜的關聯查詢或子表查詢來實現,這裏通過另外一種方式,就是再查詢一下age相同,並且id大於當前用戶的記錄條數:

select count(id) from user where age = 18 and id > 5;

上面獲得了age相同情況下,並且id大於5的記錄,將第一步和第二步的統計結果相加,問題是不是又回到了《根據ID查詢分頁位置》的簡單模式了,還是同樣的算法可以算出當前記錄位於第幾頁了。

此種方案雖然查詢了兩次數據庫,如果很好的建立索引,比關聯查詢或子查詢要方便、簡潔和高效一些。

小結

以上是在實踐中遇到類似問題的兩個思考維度,希望能給大家帶來一個突破,同時也希望大家提供更好的方案。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對神馬文庫的支持。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章