TODO:數(shù)據(jù)庫優(yōu)化之分頁-創(chuàng)新互聯(lián)
TODO:數(shù)據(jù)庫優(yōu)化之分頁
本文的例子是以MongoDB數(shù)據(jù)庫為準(zhǔn),其它數(shù)據(jù)庫各位也可以舉一反三進(jìn)行優(yōu)化。
在MongoDB中分頁使用
a.skip(n)跳過前n個匹配的文檔;
b.limit(m)返回m個結(jié)果,要是匹配的結(jié)果不到m個,則返回匹配數(shù)據(jù)量的結(jié)果,m是指定上限數(shù)量,而不是下限數(shù)量;
c.sort({“name”: 1,”address”:-1}),1表示升序,-1表示降序。
使用skip跳過少量的文檔還可以。但是數(shù)據(jù)量非常多的話,skip就會變得非常慢,每個數(shù)據(jù)庫都會有這種情況,所以要盡量避免過多的使用skip。那要怎么做分頁,我們可以利用上次的結(jié)果來計算下次的查詢。
1.使用skip的分頁
Page1 = db.user.find({}).limit(100)
Page2 = db.user.find({}).skip(100).limit(100)
Page3 = db.user.find({}).skip(200).limit(100)
2.利用上次的結(jié)果來計算下次的查詢,按時間戳(timestamp)排序
獲取第一頁
Page1 = db.user.find({}).sort({“timestamp”: -1}).limit(10)
獲取當(dāng)前頁面的最后一條記錄的時間戳lasttimestamp,
根據(jù)lasttimestamp進(jìn)行查詢下一頁數(shù)據(jù)
Nextpage=db.user.find({“timestamp”:{“$gt”:lasttimestamp}}).sort({“timestamp”: -1}).limit(10)
這樣查詢就沒有使用到skip,但是要確保timestamp唯一約束確保文檔中的數(shù)據(jù)沒有相同的值。
wxgzh:ludong86
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
網(wǎng)頁標(biāo)題:TODO:數(shù)據(jù)庫優(yōu)化之分頁-創(chuàng)新互聯(lián)
文章轉(zhuǎn)載:http://www.xueling.net.cn/article/dgspip.html