佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > Mysql高效分頁(yè)詳解

Mysql高效分頁(yè)詳解

熱門(mén)標(biāo)簽:AI電銷(xiāo) 百度競(jìng)價(jià)排名 服務(wù)外包 Linux服務(wù)器 地方門(mén)戶(hù)網(wǎng)站 鐵路電話(huà)系統(tǒng) 網(wǎng)站排名優(yōu)化 呼叫中心市場(chǎng)需求

前言

通常針對(duì)MySQL大數(shù)據(jù)量的查詢(xún)采取“分頁(yè)”策略,但是如果翻頁(yè)到比較靠后的位置時(shí)查詢(xún)將變得很慢,因?yàn)閙ysql將花費(fèi)大量的時(shí)間來(lái)掃描需要丟棄的數(shù)據(jù)。

基本分頁(yè)技巧

通常情況下,為了實(shí)現(xiàn)高效分頁(yè),需要在查詢(xún)中WHERE條件列和排序列應(yīng)用組合索引。
例如,建立索引(a,b,c)使得以下查詢(xún)可以使用索引,提高查詢(xún)效率:

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、下面查詢(xún)是無(wú)法使用以上索引的

ORDER BY a ASC, b DESC, c DESC//排序方向不一致
WHERE g = const ORDER BY b, c // 字段g不是索引一部分
WHERE a = const ORDER BY c //沒(méi)有使用字段b 
WHERE a = const ORDER BY a, d // 字段d不是索引的一部分 

解決大數(shù)據(jù)量翻頁(yè)問(wèn)題

1、將LIMIT M,N的查詢(xún)改為L(zhǎng)IMIT N
例如,使用LIMIT 10000,20,Mysql將需要讀取前10000行,然后獲取后面的20行 ,這是非常低效的,使用LIMIT N的方式,通過(guò)每頁(yè)第一條或最后一條記錄的id來(lái)做條件篩選,再配合降序和升序獲得上/下一頁(yè)的結(jié)果集 。
2、限制用戶(hù)翻頁(yè)數(shù)量
產(chǎn)品實(shí)際使用過(guò)程中用戶(hù)很少關(guān)心搜索結(jié)果的第1萬(wàn)條數(shù)據(jù)。
3、使用延遲關(guān)聯(lián)
通過(guò)使用覆蓋索引來(lái)查詢(xún)返回需要的主鍵,再根據(jù)返回的主鍵關(guān)聯(lián)原表獲得需要的行,這樣可以減少M(fèi)ysql掃描那些需要丟棄的行數(shù)。

實(shí)例:
使用索引(sex,rating)進(jìn)行查詢(xún):

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • mysql分頁(yè)原理和高效率的mysql分頁(yè)查詢(xún)語(yǔ)句
  • MySQL 百萬(wàn)級(jí)分頁(yè)優(yōu)化(Mysql千萬(wàn)級(jí)快速分頁(yè))
  • mysql limit分頁(yè)優(yōu)化方法分享
  • oracle,mysql,SqlServer三種數(shù)據(jù)庫(kù)的分頁(yè)查詢(xún)的實(shí)例
  • php+mysql分頁(yè)代碼詳解
  • mysql+php分頁(yè)類(lèi)(已測(cè))
  • mysql 分頁(yè)優(yōu)化解析
  • Mysql limit 優(yōu)化,百萬(wàn)至千萬(wàn)級(jí)快速分頁(yè) 復(fù)合索引的引用并應(yīng)用于輕量級(jí)框架
  • php下巧用select語(yǔ)句實(shí)現(xiàn)mysql分頁(yè)查詢(xún)
  • Mysql中分頁(yè)查詢(xún)的兩個(gè)解決方法比較

標(biāo)簽:黃山 銅川 湖南 仙桃 湘潭 衡水 崇左 蘭州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Mysql高效分頁(yè)詳解》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話(huà)咨詢(xún)

    • 400-1100-266
    徐闻县| 嵊州市| 繁峙县| 广昌县| 汝阳县| 仙桃市| 沙洋县| 额尔古纳市| 南川市| 客服| 丰县| 湛江市| 威海市| 新安县| 永福县| 莱西市| 江油市| 凯里市| 桃源县| 太和县| 翁源县| 鄂托克前旗| 张家川| 罗山县| 东至县| 灵山县| 海南省| 南丹县| 淮滨县| 嘉黎县| 塔河县| 元氏县| 兰西县| 西昌市| 邛崃市| 元朗区| 临清市| 丹江口市| 桃江县| 渝中区| 凉城县|