好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > MySQL分頁Limit的優化過程實戰

MySQL分頁Limit的優化過程實戰

熱門標簽:高德地圖標注模式 外呼系統防封號違法嗎 電銷機器人針對的 高德地圖標注中心個人注冊 外呼系統服務 寶應電信400電話辦理費用 如何在高德地圖標注新地址 湘潭電銷機器人咨詢電話 400電話辦理都選易號網

前言

在我們使用查詢語句的時候,經常要返回前幾條或者中間某幾行數據,這個時候怎么辦呢?不用擔心,mysql已經為我們提供了這樣一個功能。

SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset 

LIMIT 子句可以被用于強制 SELECT 語句返回指定的記錄數。LIMIT 接受一個或兩個數字參數。參數必須是一個整數常量。如果給定兩個參數,第一個參數指定第一個返回記錄行的偏移量,第二個參數指定返回記錄行的最大數目。初始記錄行的偏移量是 0(而不是 1): 為了與 PostgreSQL 兼容,MySQL 也支持句法: LIMIT # OFFSET #。

所以通常在查詢數據的時候,我們都會用到limit分頁,因為這樣避免了全表查詢,會提高查詢效率。但是在一個表的數據量多了之后,分頁查詢會明細的變慢,下面來一起看看詳細的介紹吧

MySQL分頁Limit優化

創建測試表card 2000萬數據

mysql> select count(*) from card;
+----------+
| count(*) |
+----------+
| 20000000 |
+----------+
1 row in set (0.00 sec)

-首先測試前1000行查詢速度

mysql> select * from card limit 1000,10;
+---------+--------------------------------------+
| card_id | card_number       |
+---------+--------------------------------------+
| 1001 | 13fc90a6-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1002 | 13fc923e-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1003 | 13fc93d5-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1004 | 13fc956a-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1005 | 13fc9702-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1006 | 13fc9899-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1007 | 13fc9a31-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1008 | 13fc9bc6-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1009 | 13fc9d5e-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1010 | 13fc9ef5-2e3b-11e8-ae62-9c5c8e6e37cf |
+---------+--------------------------------------+
10 rows in set (0.00 sec)

-測試100萬之后的查詢

mysql> select * from card limit 1000000,10;
+---------+--------------------------------------+
| card_id | card_number       |
+---------+--------------------------------------+
| 1000001 | 2d87021a-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000002 | 2d8703ac-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000003 | 2d87053b-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000004 | 2d8706cd-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000005 | 2d87085f-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000006 | 2d8709f1-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000007 | 2d870b83-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000008 | 2d870d18-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000009 | 2d870eaa-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000010 | 2d871039-2e3b-11e8-ae62-9c5c8e6e37cf |
+---------+--------------------------------------+
10 rows in set (0.18 sec)

-測試1000萬之后的查詢

mysql> select * from card limit 10000000,10;
+----------+--------------------------------------+
| card_id | card_number       |
+----------+--------------------------------------+
| 10000001 | b11ad76c-2e49-11e8-ae62-9c5c8e6e37cf |
| 10000002 | b11aefd5-2e49-11e8-ae62-9c5c8e6e37cf |
| 10000003 | b11af868-2e49-11e8-ae62-9c5c8e6e37cf |
| 10000004 | b11b0031-2e49-11e8-ae62-9c5c8e6e37cf |
| 10000005 | b11b07ad-2e49-11e8-ae62-9c5c8e6e37cf |
| 10000006 | b11b0f0f-2e49-11e8-ae62-9c5c8e6e37cf |
| 10000007 | b11b1669-2e49-11e8-ae62-9c5c8e6e37cf |
| 10000008 | b11b1db2-2e49-11e8-ae62-9c5c8e6e37cf |
| 10000009 | b11b24fa-2e49-11e8-ae62-9c5c8e6e37cf |
| 10000010 | b11b2c37-2e49-11e8-ae62-9c5c8e6e37cf |
+----------+--------------------------------------+
10 rows in set (1.29 sec)

可以看到越到后面查詢效率會越低。因為在查詢100萬之后的數據的時候,mysql會首先查詢100萬零10條數據,然后截取后面的十條數據。這些就造成的性能的降低。

那么怎么去避免這個掃描100萬條數據呢。我們可以明確的知道,100萬之后的主鍵是大于100萬的。所以我們可以將sql改寫,讓其用到索引,降低掃描的行數

mysql> select * from card where card_id>=1000000 limit 10;
+---------+--------------------------------------+
| card_id | card_number       |
+---------+--------------------------------------+
| 1000000 | 2d870088-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000001 | 2d87021a-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000002 | 2d8703ac-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000003 | 2d87053b-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000004 | 2d8706cd-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000005 | 2d87085f-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000006 | 2d8709f1-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000007 | 2d870b83-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000008 | 2d870d18-2e3b-11e8-ae62-9c5c8e6e37cf |
| 1000009 | 2d870eaa-2e3b-11e8-ae62-9c5c8e6e37cf |
+---------+--------------------------------------+
10 rows in set (0.00 sec)

這樣就可以很大的提高查詢效率

總結

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

您可能感興趣的文章:
  • Mysql排序和分頁(order by&limit)及存在的坑
  • MySQL用limit方式實現分頁的實例方法
  • MySQL limit使用方法以及超大分頁問題解決
  • 淺談MySQL分頁Limit的性能問題
  • MySQL Limit性能優化及分頁數據性能優化詳解
  • 淺談mysql使用limit分頁優化方案的實現
  • 詳解MySQL的limit用法和分頁查詢語句的性能分析
  • mysql limit 分頁的用法及注意要點
  • MYSQL分頁limit速度太慢的優化方法
  • MySQL limit分頁大偏移量慢的原因及優化方案

標簽:馬鞍山 宿遷 南充 黔南 黃山 蘭州 賀州 佛山

巨人網絡通訊聲明:本文標題《MySQL分頁Limit的優化過程實戰》,本文關鍵詞  MySQL,分頁,Limit,的,優化,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL分頁Limit的優化過程實戰》相關的同類信息!
  • 本頁收集關于MySQL分頁Limit的優化過程實戰的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 男女猛烈无遮挡动态视频| 91人妻人人澡人人爽人人精吕| 小东西才一个头就疼成这样| 小说儿媳妇| 《漂亮的女邻居5》HD| 91黑丝视频| 717午夜伦伦电影理论片| 91蜜桃婷婷狠狠久久综合9色| 新婚跪趴粗大撞击| 二人做受一级A片欧美一共30集| videosgrati欧美另类| 向日葵视频成人app?破解版 | 一边下奶一边吃面膜视频讲解 | 91精品丝袜久久久久久名码人妻| 在线视频国产欧美另类| 儿媳在线| 特黄特色大片免费播放器图片| 女同久久另类91精品国产| 日本一级av一片中文字幕禁欲| 菠萝视频高清视频7| 久久久久毛片免费观看| 青青草成人在线| 天天做天天爱天天做| 跟40岁的少妇做一次就不硬了| 国产V日韩V欧美综合| 长篇色翁荡熄小说全文| 女被?c??扒衣服种草莓| 家庭秘密教学动漫| 被绑到公共厕所当尿便器| 色5月综合| 久久福利免费视频| 免费看成人毛片又黄又硬又粗的瓜| 少妇性饥渴BBBBB搡BBB| 李丽莎顾欣怡欧洲杯24fa| 吃奶摸下的激烈免费视频播放| 两个人的视频www免费| 一区二区亚洲视频| 亚洲AV无码乱码国产麻豆小说| TS人妖另类精品视频系列| 关婷哪一级毛片高清免费看| 天堂A∨在线Av无码Av|