亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL分頁(yè)Limit的優(yōu)化過(guò)程實(shí)戰(zhàn)

 更新時(shí)間:2018年09月05日 15:53:57   作者:舊夢(mèng)發(fā)癲  
在mysql中進(jìn)行分頁(yè)查詢(xún)時(shí),一般會(huì)使用limit查詢(xún),下面這篇文章主要給大家介紹了關(guān)于MySQL分頁(yè)Limit優(yōu)化的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

在我們使用查詢(xún)語(yǔ)句的時(shí)候,經(jīng)常要返回前幾條或者中間某幾行數(shù)據(jù),這個(gè)時(shí)候怎么辦呢?不用擔(dān)心,mysql已經(jīng)為我們提供了這樣一個(gè)功能。

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

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

所以通常在查詢(xún)數(shù)據(jù)的時(shí)候,我們都會(huì)用到limit分頁(yè),因?yàn)檫@樣避免了全表查詢(xún),會(huì)提高查詢(xún)效率。但是在一個(gè)表的數(shù)據(jù)量多了之后,分頁(yè)查詢(xún)會(huì)明細(xì)的變慢,下面來(lái)一起看看詳細(xì)的介紹吧

MySQL分頁(yè)Limit優(yōu)化

創(chuàng)建測(cè)試表card 2000萬(wàn)數(shù)據(jù)

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

-首先測(cè)試前1000行查詢(xún)速度

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)

-測(cè)試100萬(wàn)之后的查詢(xún)

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)

-測(cè)試1000萬(wàn)之后的查詢(xún)

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)

可以看到越到后面查詢(xún)效率會(huì)越低。因?yàn)樵诓樵?xún)100萬(wàn)之后的數(shù)據(jù)的時(shí)候,mysql會(huì)首先查詢(xún)100萬(wàn)零10條數(shù)據(jù),然后截取后面的十條數(shù)據(jù)。這些就造成的性能的降低。

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

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)

這樣就可以很大的提高查詢(xún)效率

總結(jié)

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

相關(guān)文章

  • 一文教你MySQL如何優(yōu)化無(wú)索引的join

    一文教你MySQL如何優(yōu)化無(wú)索引的join

    所謂索引就是為特定的mysql字段進(jìn)行一些特定的算法排序,比如二叉樹(shù)的算法和哈希算法,哈希算法是通過(guò)建立特征值,然后根據(jù)特征值來(lái)快速查找,下面這篇文章主要給大家介紹了關(guān)于MySQL如何優(yōu)化無(wú)索引join的相關(guān)資料,需要的朋友可以參考下
    2022-01-01
  • CentOS Mysql數(shù)據(jù)庫(kù)如何實(shí)現(xiàn)定時(shí)備份

    CentOS Mysql數(shù)據(jù)庫(kù)如何實(shí)現(xiàn)定時(shí)備份

    這篇文章主要介紹了CentOS Mysql數(shù)據(jù)庫(kù)如何實(shí)現(xiàn)定時(shí)備份,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • MySQL在線(xiàn)開(kāi)啟或禁用GTID模式

    MySQL在線(xiàn)開(kāi)啟或禁用GTID模式

    本文詳細(xì)講解了MySQL在線(xiàn)開(kāi)啟或禁用GTID模式的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-11-11
  • windows 10 下安裝mysql 5.7.17的簡(jiǎn)單筆記

    windows 10 下安裝mysql 5.7.17的簡(jiǎn)單筆記

    之前一直在Linux下用MySQL,安裝也很簡(jiǎn)單,今天試一下windows下安裝,發(fā)現(xiàn)有很多坑,今天小編通過(guò)本教程給大家記錄下,一起看看吧
    2016-12-12
  • mysql清空表數(shù)據(jù)的兩種方式和區(qū)別解析

    mysql清空表數(shù)據(jù)的兩種方式和區(qū)別解析

    這篇文章主要介紹了mysql清空表數(shù)據(jù)的兩種方式和區(qū)別,本文通過(guò)文字實(shí)例代碼相結(jié)合給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-05-05
  • mysql+Spring數(shù)據(jù)庫(kù)隔離級(jí)別與性能分析

    mysql+Spring數(shù)據(jù)庫(kù)隔離級(jí)別與性能分析

    數(shù)據(jù)庫(kù)隔離級(jí)別與Spring配置事務(wù)的聯(lián)系及性能影響,以下是個(gè)人理解,如果有瑕疵請(qǐng)及時(shí)指正
    2014-05-05
  • MySQL查詢(xún)性能優(yōu)化方法匯總講解

    MySQL查詢(xún)性能優(yōu)化方法匯總講解

    這篇文章主要介紹了MySQL查詢(xún)性能優(yōu)化方法,Mysql查詢(xún)性能優(yōu)化要從三個(gè)方面考慮,庫(kù)表結(jié)構(gòu)優(yōu)化、索引優(yōu)化和查詢(xún)優(yōu)化,通常在實(shí)際應(yīng)用中,我們要面對(duì)這三種攪和一起的情況,需要了解MySQL查詢(xún)性能優(yōu)化方法的朋友可以參考下
    2024-05-05
  • 連接mysql報(bào)錯(cuò)——沒(méi)有設(shè)置“usessl=false”的問(wèn)題

    連接mysql報(bào)錯(cuò)——沒(méi)有設(shè)置“usessl=false”的問(wèn)題

    這篇文章主要介紹了連接mysql報(bào)錯(cuò)——沒(méi)有設(shè)置“usessl=false”的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • MySQL 數(shù)據(jù)類(lèi)型選擇原則

    MySQL 數(shù)據(jù)類(lèi)型選擇原則

    MySQL支持大量的數(shù)據(jù)類(lèi)型,選擇正確的類(lèi)型對(duì)性能十分關(guān)鍵。本篇介紹了MySQL 的數(shù)據(jù)類(lèi)型選擇原則,可以根據(jù)這些基本的原則確定數(shù)據(jù)表字段的具體數(shù)據(jù)類(lèi)型。
    2021-05-05
  • 虛擬主機(jī)MySQL數(shù)據(jù)庫(kù)的備份與還原的方法

    虛擬主機(jī)MySQL數(shù)據(jù)庫(kù)的備份與還原的方法

    虛擬主機(jī)MySQL數(shù)據(jù)庫(kù)的備份與還原的方法...
    2007-07-07

最新評(píng)論