BS優(yōu)化:分頁(yè)原理
文章出處:http://srpd123.com 作者:興邦開(kāi)發(fā)部 人氣: 發(fā)表時(shí)間:2016年01月04日
BS優(yōu)化:分頁(yè)原理淺析
分頁(yè),是web應(yīng)用程序非常重要的一個(gè)課題。數(shù)據(jù)庫(kù)的數(shù)據(jù)可能是幾千,幾萬(wàn),幾百萬(wàn)行,但我們不可能把幾萬(wàn)行數(shù)據(jù)一次顯示在瀏覽器上面,這樣瀏覽器受不了,用戶(hù)也受不了。一般的每頁(yè)顯示20行,是一個(gè)比較理想的顯示狀態(tài)。
分頁(yè)主要有兩種思路:
1、取出所有符合條件的數(shù)據(jù),放到數(shù)據(jù)集或者內(nèi)存當(dāng)中,然后逐頁(yè)瀏覽。那么,有可能你每頁(yè)只需瀏覽20條記錄,但要把幾百萬(wàn)行記錄取出來(lái)。我把這種分頁(yè)叫做“指針?lè)猪?yè)”。指針?lè)猪?yè)法主要是利用數(shù)據(jù)集的指針(或者集合的下標(biāo))來(lái)標(biāo)識(shí)。比如,分頁(yè)要顯示20條數(shù)據(jù),那么第一頁(yè)的指針從1開(kāi)始,第二頁(yè)的指針從(2-1)*20+1開(kāi)始,依次類(lèi)推。“指針?lè)猪?yè)”適合數(shù)據(jù)量和并發(fā)量不是很高的應(yīng)用系統(tǒng),不適合海量的數(shù)據(jù)查詢(xún)。
2、對(duì)于海量的數(shù)據(jù)查詢(xún),看多少取多少,顯然是最佳的解決辦法。假如某個(gè)表中有200萬(wàn)條記錄,第一頁(yè)就取前20條,第二頁(yè)取21~40條,這里我們用
當(dāng)前頁(yè)*每頁(yè)記錄數(shù) 表A 主鍵字段每頁(yè)記錄數(shù) 主鍵字段表。
這樣形式的語(yǔ)句來(lái)實(shí)現(xiàn)。因這種查詢(xún)方式,要用到主鍵,我們把它叫做“主鍵分頁(yè)”。
主鍵分頁(yè)在處理海量數(shù)據(jù)方面,效率是非常高的,也是首選。
對(duì)于一個(gè)完整的分頁(yè),應(yīng)當(dāng)包括總記錄數(shù)、總頁(yè)數(shù)、當(dāng)前頁(yè)數(shù)、當(dāng)前頁(yè)、每頁(yè)記錄數(shù)、向前、向后、跳轉(zhuǎn)等。所以,無(wú)論是指針?lè)猪?yè),還是主鍵分頁(yè),還得傳遞一個(gè)類(lèi)似 記錄總數(shù) 表名 這樣的語(yǔ)句,從而獲得記錄數(shù)。 顯然,主鍵分頁(yè)是首選,但是他的寫(xiě)法太復(fù)雜,太麻煩,又何況對(duì)于聯(lián)合查詢(xún)、多表查詢(xún)等情況,這個(gè)sql語(yǔ)句的寫(xiě)法,會(huì)更加復(fù)雜,會(huì)更加花費(fèi)我們有限的大腦細(xì)胞。所以,得到一種通用,同時(shí)不需要寫(xiě)那么復(fù)雜的sql語(yǔ)句的程序,同時(shí)解決普通查詢(xún)和海量查詢(xún)的分頁(yè)很有必要。