分頁優化的四種方式

轉自:http://www.orczhou.com/index.php/2009/03/four-way-pager-display/

很久以前讀了一篇關于分頁的文章,后來越想越有道理,最近又重新找出來,并做了翻譯,原文參考:Four ways to optimize paginated displays.

翻譯背景:在大數據量的情況下,原本很簡單的分頁如果沒有處理好,你會發現分頁的請求會消耗你大量的數據庫時間。如果你遇到了這個問題,文章給了你幾個很好的解決的方案。當然,初學者若能看完這篇文章,那么它會指導你寫出更具有擴展性的分頁代碼。

全文概述:文中提到了分頁的辦法總結如下:

  1. 全部緩存查詢結果。把查詢結果全部緩存起來(例如文件緩存、靜態化結果頁面等)。
  2. 不詳細顯示總共有多少分頁。這里有兩個優化的技巧。其一每次在計算總條目的時候,我就固定查詢501條,然后將前500條分頁顯示好,如果第501條確實存在,那么給出按鈕 “查看更多...”(這種情況會很少)。其二,在每次列表本頁面的時候,比如第一頁我要顯示1-20條,那么我查詢出1-21條。如果第21條真的存在,我就給出"下一頁"按鈕,依次類推。

    事實上google就是這樣做的。在查看第一頁搜索結果的時候google只會顯示前十頁(共100個條目),并不顯示搜索結果條目總共有多少:
    首頁的分頁顯示
    查看第二頁的時候,僅僅會多顯示一頁
    第二頁的分頁顯示
  3. 通過EXPLAIN的"row"列來估算結果總共有多少條目。文章中稱google是這樣估算結果集的:google總結果集

全文譯文:

?

在實際開發中,分頁顯示是我們最常遇到的優化問題之一。例如搜索結果、積分列表、排行榜等。分頁的一般模型:在一個排序的結果集合(較大)中我們要顯示其中連續20條目;并且需要顯示 “下一頁”、”上一頁”的鏈接;有時候我們還需要顯示,總共有多少個條目,一共分了多少頁。

要給出這樣一個完成顯示,數據庫的代價是很大的,有時候就為了顯示這么一個分頁,需要執行的SQL會比整個頁面顯示其他的全部SQL消耗還要大。
我曾遇到這樣的案例:有一次在為我們的一個客戶做Slow Query LOG分析的時候我們就發現:整個LOG 里面的SQL耗時6300s,其中兩個主要的分頁查詢大約消耗了(2850 + 380)秒,占了整個Slow Query的50%。
分頁沒有處理好就是這么糟糕~.

我們來分析一下分頁的一般情況:

#典型分頁的SQL如下:
SELECT .... FROM ... ORDER BY .... LIMIT X, 20

如果ORDER BY部分沒有能夠用索引的話(這樣的情況還是很多的),MYSQL就會做filesort,(注意這塊的filesort,請參看:http://www.mysqlperformanceblog.com/2009/03/05/what-does-using-filesort-mean-in-mysql/);假想如果如果滿足WHERE 條件的條目共有個百萬的數量級的話,那么MYSQL就會取出這上百萬的結果,臨時存儲、文件排序,然后再刪除大大部分的數據保留其中的20個。當用戶點擊“下一頁”的時候,上面的過程會完全重做一遍,只是取得結果向后偏了一點。要是你還想顯示“總共有多少條目,共分多少頁面”的話,一般是這樣做(1)使用SQL_CALC_FOUND_ROWS?(2)執行一個單獨的SQL去計算行數。如果用戶的每一次請求都執行以上的操作,可以想象當你的數據量越來越大的時候,情況會越來越糟。

事實上,有很多辦法去優化上面的過程的。(關于這一點我之前我寫過的一篇article on optimizing ranked data 。不過那篇文章里面介紹的辦法實施起來比較困難。所以如果不是情況復雜和重要到一定程度,就不值得那樣做。)那一般情況怎么辦呢?除了索引、重組數據、SQL優化,我們還有兩個大的方面可以考慮去做。其一,積極的把SQL的查詢結果緩存起來,從而減少SQL執行;其二就是重新考慮一下你的分頁就架構,在應用中,并不是每次都需要把分頁的各個部分都完整顯示出來的。例如你把從第1到50頁的鏈接都給出來,很多時候用戶根本不會直接去點擊某一頁。我們考慮的思路是指把最重要的部分先展示出來。

這樣考慮的于是就有了下面四個優化的建議來提高性能

  1. 首次查詢的時候緩存結果。這樣情況就變得簡單了,無論是結果條目的數量,總共的頁面數量,還是取出其中的部分條目。
  2. 不顯示總共有多少條目。Google搜索結果的分頁顯示就用了這個特性。很多時候你可能看了前幾頁,就夠了。那么我可以這樣,每次我都把結果限制在500條(這個數據越大 資源消耗越大)然后你每次查詢的時候,都查詢501條記錄,這樣,如果結果真有501個,那么我們就顯示鏈接 “顯示下500條記錄”。
  3. 不顯示總頁面數。只給出“下一頁”的鏈接,如果有下一頁的話。(如果用戶想看上一頁的話,他會通過瀏覽器來回到上一頁的)。那你可能會問我“不顯示總頁面數”怎么知道是不是有下一頁呢?這里有一個很好的小技巧:你在每次顯示你當前頁面條目的時候你都多查詢一條,例如你要顯示第11-20個條目時,你就取出11-21條記錄(多取一條,并不顯示這多取的內容),那么當你發現第21條存在的時候就顯示“下一頁的鏈接”,否則就是末頁了。這樣你就不用每次計算總頁面數量了,特別是在做緩存很困難的時候這樣做效率非常好。
  4. 估算總結果數。Google就是這么做的,事實證明效果很好。用EXPLAIN 來解釋你的SQL,然后通過EXPLAIN的結果來估算。EXPLAIN結果有一列”row”會給你一個大概的結果。(這個辦法不是處處都行,但是某些地方效果是很好的)這些辦法可以很大程度上減輕數據庫的壓力,而且對用戶體驗不會有什么影響。

這些辦法可以很大程度上減輕數據庫的壓力,而且對用戶體驗不會有什么影響。

轉載于:https://www.cnblogs.com/rollenholt/articles/3779195.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/260366.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/260366.shtml
英文地址,請注明出處:http://en.pswp.cn/news/260366.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

使用 VMControl 2.4 實現多網絡的 Power 服務器捕捉和系統部署

VMControl 作為 IBM Systems Director 的一個高級管理器,提供了一系列的管理功能幫助 Power 管理員快速捕獲部署虛擬機系統,進行虛擬化環境的管理。而現代的數據中心,出于安全性,網路負載等多重因素的考慮,一般會存在有…

windows python安裝_window 安裝 python

官網地址下載安裝包點擊下載 會自動識別你當前的系統,或者點擊你需要安裝的平臺或者選擇其他版本執行安裝高級選項說明:Install for all users 所有用戶可使用Associate files with Python 關聯PY相關的文件Create shortcuts for installed applications…

iOS應用內付費(IAP)開發步驟列表

iOS應用內付費(IAP)開發步驟列表 前兩天和服務端同事一起,完成了應用內付費(以下簡稱IAP, In app purchase)的開發工作。步驟繁多,在此把開發步驟列表整理如下。因為只是步驟列表,所以并不含詳細的說明教程&#xff0c…

【unity3d--初始學習五--c#腳本對xml文件的創建和解析】

本人用c#編寫腳本。 創建xml文件時&#xff0c;主要用到System.Xml包中的XmlDocument,XmlNode,XmlElement。下面是創建xml文檔的一般步驟&#xff1a; XmlDocument docnew XmlDocument(); //<?xml version"1.0"?> XmlNode xmlnoddoc.CreateNode(XmlNodeType.…

python計算機視覺編程(全)(強烈推薦)_推薦一個計算機視覺圖書:python計算機視覺編程...

編輯部的主頁&#xff1a;好像沒啥用每章的代碼&#xff0c;github上面的&#xff1a;中文版github上面&#xff0c;英文版&#xff1a;項目主頁&#xff1a;中文在線的書&#xff1a;然后下載安裝安裝好了以后&#xff0c;點擊自動的編輯器&#xff1a;新建工程&#xff0c;插…

mysql工具的使用_產品操作MySQL入門篇-工具使用

MYSQL本資料為產品崗位作為日常工作參考&#xff0c;語言口語化At 2019/4/15 By David.Yang數據庫怎么登錄/管理&#xff1f;登錄數據庫的方式有多種&#xff0c;比如本地Client登錄、通過數據庫管理工具登錄、通過瀏覽器訪問數據庫端WEB軟件登錄。通過各種方式登錄后&#xff…

在windows下運行spark

1.下載spark:spark-2.0.0-bin-hadoop2.7.tgz 2.解壓至D:\bigdata\spark-2.0.0-bin-hadoop2.7 3.配置環境變量 HADOOP_HOME:D:\bigdata\hadoop-2.7.2 SPARK_HOME:D:\bigdata\spark-2.0.0-bin-hadoop2.7 Path中添加&#xff1a;%HADOOP_HOME%\bin;%SPARK_HOME%\bin; 4.運行 先運行…

UIView使用UIMotionEffect效果

UIView使用UIMotionEffect效果 這個效果在模擬器上看不了,所以無法截圖. UIViewMotionEffect.h UIViewMotionEffect.m // // UIViewMotionEffect.h // // Copyright (c) 2014年 Nick Jensen. All rights reserved. //#import <UIKit/UIKit.h>interface UIView (Moti…

JavaSE_04異常處理

1. exception [ksep()n; ek-] n. 例外&#xff1b;異議 2. throw [θr] vt. 投&#xff1b;拋&#xff1b;擲 vi. 拋&#xff1b;投擲 n. 投擲&#xff1b;冒險 3. throws [θrz] n. 曲拐&#xff08;throw的復數形式&#xff09; v. 投&#xff1b;拋&#xff08;throw的三單形…

關于html和javascript在瀏覽器中的加載順序問題的討論

轉自&#xff1a;http://www.cnblogs.com/beyondstorm/archive/2008/09/17/1292940.html 前一陣子橫掃了javascript&#xff0c;當時自我感覺良好。現在一想&#xff0c;又覺得沒什么。今天的任務是把asp.net ajax中客戶端頁面生命周期那一章研究完。然而&#xff0c;因為這一章…

java 觀察者模式_Java技術干貨分享:深入理解觀察者模式原理與技術

來源&#xff1a;編程技術精選觀察者模式(Observer Pattern)也叫做發布-訂閱(Publish/Subscribe)模式、模型-視圖(Model/View)模式。這個模式的一個最重要的作用就是解耦。也就是將被觀察者和觀察者進行解耦&#xff0c;使得他們之間的依賴性更小&#xff0c;甚至做到毫無依賴。…

python導入pyecharts錯誤沒有pyecharts_python報No module named 'pyecharts'的錯誤怎么辦?

問&#xff1a;導包的時候報No module named pyecharts的錯誤怎么辦&#xff1f;答&#xff1a;報上述錯誤一般是因為pyecharts這個包沒有下載成功&#xff0c;下面給大家介紹一下pyecharts庫的安裝與使用方法&#xff01;pyecharts是Python的數據可視化庫&#xff0c;可以幫助…

iOS開發:AFNetworking、MKNetworkKit和ASIHTTPRequest比較

轉&#xff1a;http://www.xue5.com/Mobile/iOS/747036.html 之前一直在使用ASIHTTPRequest作為網絡庫&#xff0c;但是由于其停止更新&#xff0c;iOS7上可能出現更多的問題&#xff0c;于是決定更換網絡庫。 目前比較流行的網絡庫主要有AFNetworking和MKNetworkKit&#xff…

java .listfiles_Java File.listFiles()

全屏Java Java File.listFiles()方法具有以下語法。public File [] listFiles()示例在下面的代碼顯示如何使用File.listFiles()方法。import java.io.File;// At: W w W. y I i ba I.C o mpublic class Main {public static void main(String[] args) {// create new fileFile …

基礎入門_Python-內建函數.運維開發中eval內建函數的最佳實踐?

簡單介紹:說明: 在指定命名空間中計算參數字符串的有效表達式,并返回一個對象,Help on built-in function eval in module __builtin__:eval(...)eval(source[, globals[, locals]]) -> valueEvaluate the source in the context of globals and locals.The source may be a…

java簡單畢設_計算機畢業設計之自定義畢設課題需要如何確定工作量

“ 真正讓導師滿意的不是眾多普通的功能&#xff0c;而是那一抹有創意的充滿著生活氣息的小功能。”自定義畢設課題&#xff0c;我覺得這是一種體現學生創新的一種很好的手段&#xff0c;但是有一些學生卻因為腦海中沒有積累足夠多的專業知識以及也沒有對現實生活進行足夠的思考…

C#基礎系列第五篇

前言&#xff1a; 完全是我在學習過程中記錄的筆記&#xff0c;只不過分享一下讓很多剛開始學習.net編程的人能夠很快的學會C#語言 多態的一些說明(1) 多態就是為了程序的可擴展性 (2)多態的使用&#xff1a;將不同的對象當作父類來看&#xff0c;屏蔽掉各個對象間的不同&#…

羅伯特·帕丁森Robert Pattinson(2)

2019獨角獸企業重金招聘Python工程師標準>>> 轉載于:https://my.oschina.net/Bettyty/blog/756873

網博士自助建站系統_自助建站:自助建站到底好還是不好?

自助建站到底好還是不好&#xff1f;很多想要做企業網站的企業都比較關心這個問題&#xff0c;因為自助建站便宜、快&#xff0c;有的自助建站做出來的效果還非常好&#xff0c;不輸于定制的網站的效果&#xff0c;那為什么自助建站大都還很便宜呢&#xff1f;東西還好還便宜的…

linux tar.gz zip 解壓縮 壓縮命令

http://apps.hi.baidu.com/share/detail/37384818 download ADT link http://dl.google.com/android/ADT-0.9.6.zip download SDK link http://dl.google.com/android/android-sdk_r11-linux_x86.tgz(能夠通過翻墻得到詳細的文件名稱&#xff0c;再通過鏈接下載就可以) tar -c:…