成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > mysql查詢時offset過大影響性能的原因和優(yōu)化詳解

mysql查詢時offset過大影響性能的原因和優(yōu)化詳解

熱門標簽:深圳 遵義地圖標注app 外呼系統(tǒng)從哪買 德惠市地圖標注 商家地圖標注哪個好 陜西400電話如何申請 承德電腦地圖標注 地圖標注賺錢真假 合肥營銷外呼系統(tǒng)收費

前言

mysql查詢使用select命令,配合limit,offset參數(shù)可以讀取指定范圍的記錄。本文將介紹mysql查詢時,offset過大影響性能的原因及優(yōu)化方法。

準備測試數(shù)據(jù)表及數(shù)據(jù)

1.創(chuàng)建表

CREATE TABLE `member` (
 `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
 `name` varchar(10) NOT NULL COMMENT '姓名',
 `gender` tinyint(3) unsigned NOT NULL COMMENT '性別',
 PRIMARY KEY (`id`),
 KEY `gender` (`gender`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

2.插入1000000條記錄

?php
$pdo = new PDO("mysql:host=localhost;dbname=user","root",'');

for($i=0; $i1000000; $i++){
 $name = substr(md5(time().mt_rand(000,999)),0,10);
 $gender = mt_rand(1,2);
 $sqlstr = "insert into member(name,gender) values('".$name."','".$gender."')";
 $stmt = $pdo->prepare($sqlstr);
 $stmt->execute();
}
?>

mysql> select count(*) from member;
+----------+
| count(*) |
+----------+
| 1000000 |
+----------+
1 row in set (0.23 sec)

3.當前數(shù)據(jù)庫版本

mysql> select version();
+-----------+
| version() |
+-----------+
| 5.6.24 |
+-----------+
1 row in set (0.01 sec)

分析offset過大影響性能的原因

1.offset較小的情況

mysql> select * from member where gender=1 limit 10,1;
+----+------------+--------+
| id | name  | gender |
+----+------------+--------+
| 26 | 509e279687 |  1 |
+----+------------+--------+
1 row in set (0.00 sec)

mysql> select * from member where gender=1 limit 100,1;
+-----+------------+--------+
| id | name  | gender |
+-----+------------+--------+
| 211 | 07c4cbca3a |  1 |
+-----+------------+--------+
1 row in set (0.00 sec)

mysql> select * from member where gender=1 limit 1000,1;
+------+------------+--------+
| id | name  | gender |
+------+------------+--------+
| 1975 | e95b8b6ca1 |  1 |
+------+------------+--------+
1 row in set (0.00 sec)

當offset較小時,查詢速度很快,效率較高。 

2.offset較大的情況

mysql> select * from member where gender=1 limit 100000,1;
+--------+------------+--------+
| id  | name  | gender |
+--------+------------+--------+
| 199798 | 540db8c5bc |  1 |
+--------+------------+--------+
1 row in set (0.12 sec)

mysql> select * from member where gender=1 limit 200000,1;
+--------+------------+--------+
| id  | name  | gender |
+--------+------------+--------+
| 399649 | 0b21fec4c6 |  1 |
+--------+------------+--------+
1 row in set (0.23 sec)

mysql> select * from member where gender=1 limit 300000,1;
+--------+------------+--------+
| id  | name  | gender |
+--------+------------+--------+
| 599465 | f48375bdb8 |  1 |
+--------+------------+--------+
1 row in set (0.31 sec)

當offset很大時,會出現(xiàn)效率問題,隨著offset的增大,執(zhí)行效率下降。 

分析影響性能原因

select * from member where gender=1 limit 300000,1;

因為數(shù)據(jù)表是InnoDB,根據(jù)InnoDB索引的結(jié)構(gòu),查詢過程為:

  • 通過二級索引查到主鍵值(找出所有g(shù)ender=1的id)。
  • 再根據(jù)查到的主鍵值通過主鍵索引找到相應(yīng)的數(shù)據(jù)塊(根據(jù)id找出對應(yīng)的數(shù)據(jù)塊內(nèi)容)。
  • 根據(jù)offset的值,查詢300001次主鍵索引的數(shù)據(jù),最后將之前的300000條丟棄,取出最后1條。

不過既然二級索引已經(jīng)找到主鍵值,為什么還需要先用主鍵索引找到數(shù)據(jù)塊,再根據(jù)offset的值做偏移處理呢?

如果在找到主鍵索引后,先執(zhí)行offset偏移處理,跳過300000條,再通過第300001條記錄的主鍵索引去讀取數(shù)據(jù)塊,這樣就能提高效率了。

如果我們只查詢出主鍵,看看有什么不同

mysql> select id from member where gender=1 limit 300000,1;
+--------+
| id  |
+--------+
| 599465 |
+--------+
1 row in set (0.09 sec)

很明顯,如果只查詢主鍵,執(zhí)行效率對比查詢?nèi)孔侄?,有很大的提升?nbsp; 

推測

只查詢主鍵的情況

因為二級索引已經(jīng)找到主鍵值,而查詢只需要讀取主鍵,因此mysql會先執(zhí)行offset偏移操作,再根據(jù)后面的主鍵索引讀取數(shù)據(jù)塊。

需要查詢所有字段的情況

因為二級索引只找到主鍵值,但其他字段的值需要讀取數(shù)據(jù)塊才能獲取。因此mysql會先讀出數(shù)據(jù)塊內(nèi)容,再執(zhí)行offset偏移操作,最后丟棄前面需要跳過的數(shù)據(jù),返回后面的數(shù)據(jù)。 

證實

InnoDB中有buffer pool,存放最近訪問過的數(shù)據(jù)頁,包括數(shù)據(jù)頁和索引頁。

為了測試,先把mysql重啟,重啟后查看buffer pool的內(nèi)容。

mysql> select index_name,count(*) from information_schema.INNODB_BUFFER_PAGE where INDEX_NAME in('primary','gender') and TABLE_NAME like '%member%' group by index_name;
Empty set (0.04 sec)

可以看到,重啟后,沒有訪問過任何的數(shù)據(jù)頁。

查詢所有字段,再查看buffer pool的內(nèi)容

mysql> select * from member where gender=1 limit 300000,1;
+--------+------------+--------+
| id  | name  | gender |
+--------+------------+--------+
| 599465 | f48375bdb8 |  1 |
+--------+------------+--------+
1 row in set (0.38 sec)

mysql> select index_name,count(*) from information_schema.INNODB_BUFFER_PAGE where INDEX_NAME in('primary','gender') and TABLE_NAME like '%member%' group by index_name;
+------------+----------+
| index_name | count(*) |
+------------+----------+
| gender  |  261 |
| PRIMARY |  1385 |
+------------+----------+
2 rows in set (0.06 sec)

可以看出,此時buffer pool中關(guān)于member表有1385個數(shù)據(jù)頁,261個索引頁。 

重啟mysql清空buffer pool,繼續(xù)測試只查詢主鍵

mysql> select id from member where gender=1 limit 300000,1;
+--------+
| id  |
+--------+
| 599465 |
+--------+
1 row in set (0.08 sec)

mysql> select index_name,count(*) from information_schema.INNODB_BUFFER_PAGE where INDEX_NAME in('primary','gender') and TABLE_NAME like '%member%' group by index_name;
+------------+----------+
| index_name | count(*) |
+------------+----------+
| gender  |  263 |
| PRIMARY |  13 |
+------------+----------+
2 rows in set (0.04 sec)

可以看出,此時buffer pool中關(guān)于member表只有13個數(shù)據(jù)頁,263個索引頁。因此減少了多次通過主鍵索引訪問數(shù)據(jù)塊的I/O操作,提高執(zhí)行效率。

因此可以證實,mysql查詢時,offset過大影響性能的原因是多次通過主鍵索引訪問數(shù)據(jù)塊的I/O操作。(注意,只有InnoDB有這個問題,而MYISAM索引結(jié)構(gòu)與InnoDB不同,二級索引都是直接指向數(shù)據(jù)塊的,因此沒有此問題 )。 

InnoDB與MyISAM引擎索引結(jié)構(gòu)對比圖

這里寫圖片描述

優(yōu)化方法

根據(jù)上面的分析,我們知道查詢所有字段會導(dǎo)致主鍵索引多次訪問數(shù)據(jù)塊造成的I/O操作。

因此我們先查出偏移后的主鍵,再根據(jù)主鍵索引查詢數(shù)據(jù)塊的所有內(nèi)容即可優(yōu)化。

mysql> select a.* from member as a inner join (select id from member where gender=1 limit 300000,1) as b on a.id=b.id;
+--------+------------+--------+
| id  | name  | gender |
+--------+------------+--------+
| 599465 | f48375bdb8 |  1 |
+--------+------------+--------+
1 row in set (0.08 sec)

附:MYSQL limit,offset 區(qū)別

SELECT
  keyword
FROM
  keyword_rank
WHERE
  advertiserid='59'
order by
  keyword
LIMIT 2 OFFSET 1;

比如這個SQL ,limit后面跟的是2條數(shù)據(jù),offset后面是從第1條開始讀取

SELECT
  keyword
FROM
  keyword_rank
WHERE
  advertiserid='59'
ORDER BY
  keyword
LIMIT 2 ,1;

而這個SQL,limit后面是從第2條開始讀,讀取1條信息。

這兩個千萬別搞混哦。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • MySQL性能優(yōu)化之如何高效正確的使用索引
  • MySQL數(shù)據(jù)庫查詢性能優(yōu)化策略
  • Mysql高性能優(yōu)化技能總結(jié)
  • MySQL性能優(yōu)化神器Explain的基本使用分析
  • 通過MySQL慢查詢優(yōu)化MySQL性能的方法講解
  • MySQL Limit性能優(yōu)化及分頁數(shù)據(jù)性能優(yōu)化詳解
  • MySQL中聚合函數(shù)count的使用和性能優(yōu)化技巧
  • mysql千萬級數(shù)據(jù)分頁查詢性能優(yōu)化
  • MYSQL開發(fā)性能研究之批量插入數(shù)據(jù)的優(yōu)化方法
  • MySQL性能優(yōu)化技巧分享

標簽:貴州 南陽 贛州 巴中 新余 商丘 揚州 三門峽

巨人網(wǎng)絡(luò)通訊聲明:本文標題《mysql查詢時offset過大影響性能的原因和優(yōu)化詳解》,本文關(guān)鍵詞  mysql,查詢,時,offset,過大,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《mysql查詢時offset過大影響性能的原因和優(yōu)化詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于mysql查詢時offset過大影響性能的原因和優(yōu)化詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    日产乱码一卡二卡三免费| 日本丰满少妇黄大片在线观看| 91成人抖音| avove在线观看| 久久精品国产精品亚洲| 国产欧美精品va在线观看| 日韩欧美精品在线不卡| 奇米影视第四色777| 91久久国产综合久久| 国产在线激情视频| 中文字幕 日韩 欧美| 毛片在线播放网址| 欧美日韩在线免费视频| 国产欧美日韩最新| 天天做天天爱综合| 亚洲卡通欧美制服中文| 亚洲av人人澡人人爽人人夜夜| 日韩精品一级中文字幕精品视频免费观看| 精品在线视频一区二区三区| 三级黄在线观看| 亚洲中国最大av网站| 久久久人成影片一区二区三区| 精品视频在线免费看| 蜜臀91精品一区二区三区| 欧美特黄色片| 亚洲香蕉av在线一区二区三区| 日韩精品视频免费在线观看| 欧美手机在线观看| 麻豆亚洲精品| 亚洲五码在线| 女人裸体免费网站| 91精品国产黑色紧身裤美女| 日韩成人亚洲| 天堂在线视频中文网| 日韩欧美国产中文字幕| 国产女人在线视频| 亚洲综合图色| 极品美鲍一区| 中文字幕在线日韩| 99久久99久久免费精品小说| 国产亲伦免费视频播放| 在线观看黄色国产| 国产精品成人国产乱一区| 17c丨国产丨精品视频| 国产精品传媒麻豆hd| 超碰97人人干| 久操手机在线视频| 免费一级片在线观看| 丝袜美腿综合| 欧美国产一区二区在线| 三级成人在线| 久久天天躁夜夜躁狠狠躁2022| 麻豆精品免费视频入口| 看女生喷水的网站在线观看| 成人视屏免费看| 美女在线不卡| 亚洲精品成人久久| 国产在线精品不卡| 国产福利一区二区在线精品| 看片网址国产福利av中文字幕| 88av在线| 免费视频91| 噜噜噜久久,亚洲精品国产品| 国产成人综合亚洲91猫咪| 日夜操在线视频| 国产91精品在线| 青青青国内视频在线观看软件| 欧美日韩国产精品一区二区三区四区| 在线国产三级| 天堂一区二区三区四区| 精品一区av| 久久伊人一区| 国内精品福利视频| 麻豆久久一区二区| 日韩久久免费电影| 亚洲综合小说图片| 中文字幕高清在线免费播放| 国产精品日日摸夜夜爽| 国产又粗又猛又爽又黄| 爱草在线视频| 寂寞护士中文字幕mp4| 亚洲mm色国产网站| 日韩综合第一页| 亚洲日本视频| 欧美日韩性生活| 欧美高清一级片| 怡红院红怡院欧美aⅴ怡春院| 欧美亚洲国产一卡| 一区二区三区国| 亚洲图片欧美一区| 91视频精品在这里| 国产精品高清一区二区三区| 一区二区小视频| 欧美性xxx| 久久精品人人做人人综合| 2019一级黄色毛片免费看网| 久久综合图区亚洲综合图区| 伊人影院蕉久影院在线观看| 羞羞答答一区二区| 久久久免费网站| 亚洲成人一区二区| 黄色一级免费视频| 好男人免费精品视频| 一本久久知道综合久久| 九九热精品在线观看| 欧美激情在线播放| 国产97色在线|日韩| 国产福利在线视频| 国产一区二区视频在线| 欧美性受xxxx黑人xyx性爽| 国产不卡视频在线观看| 欧美激情 亚洲a∨综合| 日韩视频在线观看免费视频| 丰满湿润大白屁股bbw按摩| 国产视频网站在线观看| xxx性欧美| 国产免费一区二区三区在线能观看| 精品一区二区三区影院在线午夜| 中文字幕第一页亚洲| www.日日夜夜| 国产精品久久久一本精品| 国产精品pans私拍| 国产精品99久久久久久久vr| 91免费视频网| 求av网址在线观看| 欧美精品一区在线播放| 性囗交免费视频观看| 欧美久久一级| 99久久精品久久亚洲精品| 免费成人美女女在线观看| 国产aⅴ夜夜欢一区二区三区| 成人动漫在线免费观看| 国产chinese精品一区二区| 制服丝袜在线播放| 国内精品麻豆美女在线播放视频| 欧美三级小视频| 成人动漫在线视频| 丝袜在线视频| 91在线观看下载| 国产在线播放91| 国产有码在线观看| 亚洲精品视频一区二区| 亚洲国产另类久久久精品极度| 91网站最新地址| 四虎国产精品永久地址998| 一本大道久久a久久综合| 免费观看的黄色网址| 欧美一区二区国产| 亚洲欧洲免费视频| 麻豆短视频在线观看| 9191在线视频| 亚洲av无码一区二区二三区| 看黄色录像一级片| 国产污视频在线播放| 久久精品视频在线观看| 亚洲黄一区二区三区| 最新av中文字幕| 精品欧美一区二区三区在线观看| 欧美精品久久久久久久免费观看| 老司机在线永久免费观看| 91色婷婷久久久久合中文| 欧美一级爆毛片| 日本1区2区| 黄页视频在线91| 在线看国产视频| 91小视频在线免费看| 国产福利久久| 国产一区二区三区日韩欧美| 欧美最猛黑人xxxxwww| 日韩大片在线| 亚洲欧洲一区二区三区久久| 国产午夜精品一区二区三区四区| 久久免费午夜影院| 2欧美一区二区三区在线观看视频| 四虎.com| 亚洲人妖av一区二区| 欧美人与禽猛交乱配| 国产第一页在线| 久久成人免费日本黄色| 美女毛片在线看| 在线播放国产一区二区三区| 亚洲区精品久久一区二区三区| 日韩美女写真福利在线观看| 尤物视频一区二区| 欧美一级淫片丝袜脚交| 蜜桃精品视频在线观看| 国产精品欧美激情| 麻豆精品蜜桃一区二区三区| www.蜜桃av| vam成人资源在线观看| 亚洲高清免费观看高清完整版| 亚洲国产精品久久久久婷婷软件| 卡通动漫亚洲综合| 91精品在线视频观看| 欧美gayvideo| 欧美大片网站在线观看| 九九精品免费视频| 国产精品久久久久久久久久久久久久| 国产精品欧美日韩久久| 久久亚洲国产精品成人av秋霞| 亚洲久色影视| 日韩视频第二页| 色天使久久综合网天天| 精品午夜一区二区三区| 欧美另类中文字幕| 国内精品久久久久久久久电影网| 欧美另类极品videosbest视| 亚洲人成无码www久久久| 久久国产精品一区二区三区| 日韩久久一区二区三区| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 懂色一区二区三区| 成人国产精品av| 亚洲人成啪啪网站| 国产精品久久久久久久久久久不卡| 欧美精品一区二区三区在线看午夜| 国产精品看片你懂得| 电影亚洲精品噜噜在线观看| 日韩亚洲欧美成人一区| 亚洲欧洲无码一区二区三区| 杨幂毛片午夜性生毛片| 国产欧美在线| 亚洲自拍另类欧美丝袜| 成人午夜精品久久久久久久蜜臀| www 成人av com| 激情欧美日韩一区二区| 18岁以下禁止观看的美女视频| 亚洲网站视频福利| 999在线免费视频| 国产女片a归国片aa| 激情在线观看视频| 色偷偷av一区二区三区| 久久69国产一区二区蜜臀| 亚洲女同二女同志奶水| 欧美大喷水吹潮合集在线观看| 97视频热人人精品免费| 欧美日韩国产一区二区三区地区| 91精品视频在线| 人妻av中文系列| 日韩高清免费观看| 日韩av黄色在线| 亚洲伦理影院| 欧美另类视频在线观看| 国产女人高潮毛片| 欧美成a人片在线观看久| 亚洲欧美福利视频| 久久亚洲精精品中文字幕早川悠里| 日本电影亚洲天堂| 日本v片在线高清不卡在线观看| 亚洲日本伦理| 奇米色在线视频| 韩日视频在线观看| www.四虎.com| 亚洲黄色成人网| 成 年 人 黄 色 大 片大 全| 麻豆视频在线观看| 中文字幕一区三区| www在线观看播放免费视频日本| 人妻激情偷乱频一区二区三区| 欧美亚洲愉拍一区二区| 国产精品成人av久久| 国产精品91免费在线| 久热精品在线视频| 亚洲伦理一区| 曰本大片免费观看视频| 欧美1o一11sex性hdhd| 日本一区二区三区四区视频| 91在线资源站| www.浪潮av.com| 亚洲国产成人在人网站天堂| 深夜福利视频在线免费观看| 日韩av中文| 国产精品网曝门| 91久久中文字幕| 国产精品无码粉嫩小泬| 91tv亚洲精品香蕉国产一区| 国产精品美女久久久浪潮软件| 国产女主播一区二区三区| 色欲色香天天天综合网www| 一区二区欧美日韩视频| 国产亚洲成av人片在线观看桃| 亚洲精品自拍视频| 亚洲三级电影| 在线观看中文字幕2021| 中文字幕在线观看一区二区三区| 国产精品私人影院| 日韩美女在线看免费观看| 久久精品国产77777蜜臀| 日韩精品视频免费看| 天堂精品在线视频| 7777精品伊久久久大香线蕉语言| 1024av视频| 免费成人性网站| 午夜影院福利社| 亚洲狠狠丁香婷婷综合久久久| 精产国品自在线www| 中文字幕第38页| 幼a在线观看| 成年人黄色大片在线| 亚洲欧美在线播放| 成人动漫一区二区三区| 九色视频在线观看免费播放| 中文乱码字幕高清一区二区| 麻豆精品91| 午夜色在线观看| 日本在线www| 青青操国产视频| 狠狠干在线视频| 亚洲动漫第一页| 欧美片一区二区| 美日韩精品视频免费看| 中文字幕天天干| 在线中文字幕av| 欧美日韩一区综合| av在线app| 风间由美一区二区三区| 国产精品资源网站| 日本一区二区在线免费观看| av在线天堂| 污污的网站18| 欧洲美女女同性互添| 日韩欧美一区二区三区在线| 久久三级视频| 一本色道a无线码一区v| 亚洲久草视频| 午夜精品久久久久久不卡8050| 久久九九国产精品怡红院| 西西裸体人体做爰大胆久久久|