国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

Mysql高效分頁詳解

2024-07-24 13:11:56
字體:
來源:轉載
供稿:網友

前言

通常針對MySQL大數據量的查詢采取“分頁”策略,但是如果翻頁到比較靠后的位置時查詢將變得很慢,因為mysql將花費大量的時間來掃描需要丟棄的數據。

基本分頁技巧

通常情況下,為了實現高效分頁,需要在查詢中WHERE條件列和排序列應用組合索引。
例如,建立索引(a,b,c)使得以下查詢可以使用索引,提高查詢效率:

1、字段排序

ORDER BY a ORDER BY a,bORDER 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不是索引的一部分 

解決大數據量翻頁問題

1、將LIMIT M,N的查詢改為LIMIT N
例如,使用LIMIT 10000,20,Mysql將需要讀取前10000行,然后獲取后面的20行 ,這是非常低效的,使用LIMIT N的方式,通過每頁第一條或最后一條記錄的id來做條件篩選,再配合降序和升序獲得上/下一頁的結果集 。
2、限制用戶翻頁數量
產品實際使用過程中用戶很少關心搜索結果的第1萬條數據。
3、使用延遲關聯
通過使用覆蓋索引來查詢返回需要的主鍵,再根據返回的主鍵關聯原表獲得需要的行,這樣可以減少Mysql掃描那些需要丟棄的行數。

實例:
使用索引(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>);

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 巴林右旗| 台北县| 礼泉县| 元谋县| 繁昌县| 西乌| 沙雅县| 襄垣县| 门源| 云龙县| 巴南区| 南投县| 万载县| 闽侯县| 成安县| 柘荣县| 叶城县| 加查县| 白朗县| 鸡泽县| 昌黎县| 永修县| 灵石县| 揭阳市| 白朗县| 盱眙县| 富源县| 青铜峡市| 丽水市| 吉木萨尔县| 江城| 湖北省| 佛山市| 泾阳县| 彰化市| 宜良县| 阿克| 凤翔县| 左贡县| 尚志市| 精河县|