Mysql高效分頁詳解
前言
通常針對MySQL大數(shù)據(jù)量的查詢采取“分頁”策略,但是如果翻頁到比較靠后的位置時查詢將變得很慢,因為mysql將花費大量的時間來掃描需要丟棄的數(shù)據(jù)。
基本分頁技巧
通常情況下,為了實現(xiàn)高效分頁,需要在查詢中WHERE條件列和排序列應(yīng)用組合索引。
例如,建立索引(a,b,c)使得以下查詢可以使用索引,提高查詢效率:
1、字段排序
ORDER BY a ORDER BY a,b ORDER BY a, b, c ORDER BY a DESC, b DESC, c DESC
2、篩選和排序
WHERE a = const ORDER BY b, c WHERE a = const AND b = const ORDER BY c WHERE a = const ORDER BY b, c WHERE a = const AND b > const ORDER BY b, c
3、下面查詢是無法使用以上索引的
ORDER BY a ASC, b DESC, c DESC//排序方向不一致 WHERE g = const ORDER BY b, c // 字段g不是索引一部分 WHERE a = const ORDER BY c //沒有使用字段b WHERE a = const ORDER BY a, d // 字段d不是索引的一部分
解決大數(shù)據(jù)量翻頁問題
1、將LIMIT M,N的查詢改為LIMIT N
例如,使用LIMIT 10000,20,Mysql將需要讀取前10000行,然后獲取后面的20行 ,這是非常低效的,使用LIMIT N的方式,通過每頁第一條或最后一條記錄的id來做條件篩選,再配合降序和升序獲得上/下一頁的結(jié)果集 。
2、限制用戶翻頁數(shù)量
產(chǎn)品實際使用過程中用戶很少關(guān)心搜索結(jié)果的第1萬條數(shù)據(jù)。
3、使用延遲關(guān)聯(lián)
通過使用覆蓋索引來查詢返回需要的主鍵,再根據(jù)返回的主鍵關(guān)聯(lián)原表獲得需要的行,這樣可以減少Mysql掃描那些需要丟棄的行數(shù)。
實例:
使用索引(sex,rating)進行查詢:
mysql> SELECT <cols> FROM profiles INNER JOIN ( -> SELECT <primary key cols> FROM profiles -> WHERE x.sex='M' ORDER BY rating LIMIT 100000, 10 -> ) AS x USING(<primary key cols>);
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
數(shù)據(jù)庫管理中19個MySQL優(yōu)化方法
小編給大家總結(jié)了19條非常實用的MySQL數(shù)據(jù)庫優(yōu)化方法,這是每個服務(wù)器管理人員都必須知道的,一起學習下。2017-11-11MYSQL中查詢LONGBLOB類型數(shù)據(jù)的大小的詳細示例
在MySQL中,LONGBLOB?是一種二進制大對象(BLOB)數(shù)據(jù)類型,用于存儲大量的二進制數(shù)據(jù),但是,LONGBLOB?數(shù)據(jù)類型本身并不直接存儲數(shù)據(jù)的大?。ㄩL度),它存儲的是二進制數(shù)據(jù)的實際內(nèi)容,這篇文章主要介紹了MYSQL中怎么查詢LONGBLOB類型數(shù)據(jù)的大小,需要的朋友可以參考下2024-06-06Win10安裝MySQL5.7.18winX64 啟動服務(wù)器失敗并且沒有錯誤提示
這篇文章主要介紹了Win10安裝MySQL5.7.18winX64 啟動服務(wù)器失敗并且沒有錯誤提示,需要的朋友可以參考下2017-06-06CentOS7下 MySQL定時自動備份的實現(xiàn)方法
這篇文章主要介紹了CentOS7 下MySQL定時自動備份的實現(xiàn)方法,主要實現(xiàn)了數(shù)據(jù)庫備份,清理過期備份文件功能,需要的朋友可以參考下2019-12-12MySQL 5.7.16 修改密碼提示 ERROR 1054 (42S22): Unknown column ''''p
這篇文章主要介紹了MySQL 5.7.16 修改密碼提示 ERROR 1054 (42S22): Unknown column 'password' in 'field list'的原因分析及解決辦法,需要的朋友可以參考下2017-01-01