校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Mysql高效分頁詳解

Mysql高效分頁詳解

熱門標簽:沈陽智能外呼系統供應商 如何選擇優質的外呼系統 東莞外呼企業管理系統 清遠申請400電話 南通電銷外呼系統哪家強 地圖簡圖標注 桂林云電銷機器人收費 谷歌地圖標注位置圖解 手機外呼系統違法嗎

前言

通常針對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>);

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

您可能感興趣的文章:
  • mysql分頁原理和高效率的mysql分頁查詢語句
  • MySQL 百萬級分頁優化(Mysql千萬級快速分頁)
  • mysql limit分頁優化方法分享
  • oracle,mysql,SqlServer三種數據庫的分頁查詢的實例
  • php+mysql分頁代碼詳解
  • mysql+php分頁類(已測)
  • mysql 分頁優化解析
  • Mysql limit 優化,百萬至千萬級快速分頁 復合索引的引用并應用于輕量級框架
  • php下巧用select語句實現mysql分頁查詢
  • Mysql中分頁查詢的兩個解決方法比較

標簽:臨沂 貴州 成都 天津 內蒙古 湖州 常德 重慶

巨人網絡通訊聲明:本文標題《Mysql高效分頁詳解》,本文關鍵詞  Mysql,高效,分頁,詳解,Mysql,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Mysql高效分頁詳解》相關的同類信息!
  • 本頁收集關于Mysql高效分頁詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 黑山县| 丰都县| 英超| 乡城县| 安康市| 盐山县| 西贡区| 普定县| 通榆县| 高邑县| 芮城县| 运城市| 祥云县| 光泽县| 韩城市| 临沭县| 福鼎市| 丰原市| 兴安县| 洛南县| 金门县| 海宁市| 武清区| 林西县| 抚州市| 合阳县| 道孚县| 平谷区| 宽城| 安福县| 连江县| 新河县| 全椒县| 英吉沙县| 东光县| 洞口县| 新蔡县| 兴隆县| 星座| 灵武市| 保康县|