程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> Mysql高效分頁詳解

Mysql高效分頁詳解

編輯:MySQL綜合教程

Mysql高效分頁詳解。本站提示廣大學習愛好者:(Mysql高效分頁詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是Mysql高效分頁詳解正文


前言

通常針對MySQL大數據量的查詢采取“分頁”戰略,但是假如翻頁到比擬靠後的地位時查詢將變得很慢,由於mysql將破費少量的時間來掃描需求丟棄的數據。

根本分頁技巧

通常狀況下,為了完成高效分頁,需求在查詢中WHERE條件列和排序列使用組合索引。
例如,樹立索引(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不是索引的一局部 

處理大數據量翻頁問題

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>);

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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved