国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

Mysql高效分頁詳解

2024-07-24 12:52:44
字體:
供稿:網(wǎng)友

前言

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

基本分頁技巧

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

1、字段排序

ORDER BY a ORDER BY a,bORDER 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不是索引的一部分

解決大數(shù)據(jù)量翻頁問題

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

實(shí)例:
使用索引(sex,rating)進(jì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>);

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持錯(cuò)新站長站。

您可能感興趣的文章:

mysql分頁原理和高效率的mysql分頁查詢語句MySQL 百萬級分頁優(yōu)化(Mysql千萬級快速分頁)mysql limit分頁優(yōu)化方法分享oracle,mysql,SqlServer三種數(shù)據(jù)庫的分頁查詢的實(shí)例php+mysql分頁代碼詳解mysql+php分頁類(已測)mysql 分頁優(yōu)化解析Mysql limit 優(yōu)化,百萬至千萬級快速分頁 復(fù)合索引的引用并應(yīng)用于輕量級框架php下巧用select語句實(shí)現(xiàn)mysql分頁查詢Mysql中分頁查詢的兩個(gè)解決方法比較
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 怀集县| 珠海市| 临邑县| 青海省| 枝江市| 尼勒克县| 民县| 南岸区| 阿拉尔市| 合江县| 秦安县| 卓资县| 穆棱市| 小金县| 都江堰市| 锡林浩特市| 彭山县| 洛南县| 牟定县| 汉川市| 巴林右旗| 神木县| 常德市| 临西县| 二连浩特市| 托克逊县| 梓潼县| 密云县| 民县| 舒兰市| 阿鲁科尔沁旗| 郁南县| 雅江县| 彭泽县| 永新县| 黔西| 田阳县| 博乐市| 阜宁县| 利津县| 盐源县|