欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL 分頁查詢的優(yōu)化技巧

 更新時(shí)間:2021年05月12日 10:30:10   作者:島上碼農(nóng)  
這篇文章主要介紹了MySQL 分頁查詢的優(yōu)化技巧,幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下

在有分頁查詢的應(yīng)用中,包括 LIMIT 和 OFFSET 的查詢十分常見,而且?guī)缀趺總€(gè)都會(huì)有一個(gè) ORDER BY 子句。如果使用索引排序的話將對(duì)性能優(yōu)化十分有幫助,否則服務(wù)端需要做很多文件排序。

一個(gè)高頻的問題是 offset 的值過大。如果查詢類似 LIMIT 10000, 20,將會(huì)產(chǎn)生10020行,并將之前的10000行丟棄,這樣的代價(jià)很高。假設(shè)所有的頁使用相同的頻次訪問,這樣的查詢將平均掃描一半數(shù)據(jù)表。為了優(yōu)化他們,你可以在分頁視圖中限制最多可訪問的頁數(shù),或者讓大便宜的查詢更有效。

一個(gè)改善性能簡(jiǎn)單的技巧是在覆蓋索引上進(jìn)行查詢操作而不是整行數(shù)據(jù)。你可以將結(jié)果與完整的行做一次聯(lián)合然后再獲取額外需要的列。這樣的效率會(huì)更高,例如下面的查詢:

SELECT film_id, description FROM sakila.film ORDER BY title LIMIT 50, 5;

如果數(shù)據(jù)表很大的話,則可以按下面的方式進(jìn)行優(yōu)化:

SELECT film.film_id, film.description
FROM sakila.film
	INNER JOIN (
    SELECT film_id FROM sakila.film
    ORDER BY title LIMIT 50, 5)
  ) as lim USING(film_id);

這種“推斷聯(lián)合查詢”能夠有效工作是因?yàn)樗褂昧怂饕郎p少了服務(wù)端盡可能少地訪問數(shù)據(jù)行去檢查數(shù)據(jù)。一旦復(fù)核要求的行查到了,將他們與對(duì)應(yīng)的數(shù)據(jù)表的行進(jìn)行聯(lián)合查詢以獲取對(duì)應(yīng)行的其他列。

有些時(shí)候也可以將 limit 轉(zhuǎn)換為固定位置的查詢,這種方式可以對(duì)索引進(jìn)行范圍掃描完成。例如,如果你預(yù)先計(jì)算一個(gè)固定位置的列 稱之為 position,可以重寫查詢?nèi)缦拢?/p>

SELECT film_id, description FROM sakila.film
WHERE position BETWEEN 50 AND 54 ORDER BY position;

排序的數(shù)據(jù)也可以使用類似的方式解決,但是通常會(huì)被 GROUP BY操作影響。大部分情況下需要提前計(jì)算和存儲(chǔ)排序值。

LIMIT 和 OFFSET 真正的問題是在OFFSET,這意味著服務(wù)端會(huì)把很多數(shù)據(jù)行丟棄。如果使用一個(gè)有序書簽來記錄下次獲取行的位置的話,則可以從上次的位置開始訪問接下來的數(shù)據(jù)。例如,如果你需要對(duì)出租記錄進(jìn)行分頁,從最新的出租記錄開始往回查詢,則可以依賴于記錄的主鍵是一直增加的,因此可以對(duì)第一頁數(shù)據(jù)這樣查詢:

SELECT * FROM sakila.rental
ORDER BY rental_id DESC LIMIT 20;

這個(gè)查詢返回16049到16030之間的數(shù)據(jù)。接下來的查詢可以從之前結(jié)束位置開始:

SELECT * FROM sakila.rental
WHERE rental_id < 16030 
ORDER BY rental_id DESC LIMIT 20;

這個(gè)技巧不管你從多遠(yuǎn)的偏移值開始查詢都是很有效的。

其他的一些技巧包括使用預(yù)先計(jì)算的統(tǒng)計(jì)值,或者通過聯(lián)合冗余了主鍵和排序列的數(shù)據(jù)表進(jìn)行查詢,這兩種方式都是通過空間換取時(shí)間的方式提高查詢效率。

以上就是MySQL 分頁查詢的優(yōu)化技巧的詳細(xì)內(nèi)容,更多關(guān)于MySQL 分頁查詢的優(yōu)化的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Ubuntu配置Mysql主從數(shù)據(jù)庫

    Ubuntu配置Mysql主從數(shù)據(jù)庫

    MySQL數(shù)據(jù)庫支持?jǐn)?shù)據(jù)庫的主從復(fù)制功能,因此在集群方面具有其獨(dú)特的優(yōu)勢(shì)。眾多國(guó)內(nèi)外大型網(wǎng)站架構(gòu)體系中,均采用了MySQL的主從數(shù)據(jù)庫配置來實(shí)現(xiàn)查詢負(fù)載、數(shù)據(jù)庫熱備等功能。本人在實(shí)際的Web項(xiàng)目中也涉及到這一需求,在此將如何配置實(shí)現(xiàn)做個(gè)簡(jiǎn)單小結(jié)。
    2014-07-07
  • windows server2014 安裝 Mysql Applying Security出錯(cuò)的完美解決方法

    windows server2014 安裝 Mysql Applying Security出錯(cuò)的完美解決方法

    這篇文章給大家介紹了windows server2014 安裝 Mysql Applying Security出錯(cuò)的完美解決方法,造成這種問題的主要原因是因?yàn)榘惭b一遍之后沒有卸載干凈,要解決這個(gè)問題需要注意以下幾點(diǎn),具體解決方法,大家參考下本文
    2017-07-07
  • 簡(jiǎn)單了解mysql InnoDB MyISAM相關(guān)區(qū)別

    簡(jiǎn)單了解mysql InnoDB MyISAM相關(guān)區(qū)別

    這篇文章主要介紹了簡(jiǎn)單了解mysql InnoDB MyISAM相關(guān)區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • 全面了解MySql中的事務(wù)

    全面了解MySql中的事務(wù)

    下面小編就為大家?guī)硪黄媪私釳ySql中的事務(wù)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-06-06
  • MySQL數(shù)據(jù)庫的高可用方案總結(jié)

    MySQL數(shù)據(jù)庫的高可用方案總結(jié)

    這篇文章主要針對(duì)MySQL數(shù)據(jù)庫的高可用方案進(jìn)行詳細(xì)總結(jié),高可用架構(gòu)對(duì)于互聯(lián)網(wǎng)服務(wù)基本是標(biāo),本文是對(duì)各種方案的總結(jié),感興趣的小伙伴們可以參考一下
    2016-05-05
  • mysql 獲取當(dāng)天發(fā)布的信息的語句

    mysql 獲取當(dāng)天發(fā)布的信息的語句

    mysql 獲取當(dāng)天發(fā)布的信息的實(shí)現(xiàn)語句,需要的朋友可以參考下。
    2010-03-03
  • NaviCat連接時(shí)提示"不支持遠(yuǎn)程連接的MySql數(shù)據(jù)庫"解決方法

    NaviCat連接時(shí)提示"不支持遠(yuǎn)程連接的MySql數(shù)據(jù)庫"解決方法

    前段時(shí)間,因?yàn)橐豁?xiàng)目,需要做MYSql的數(shù)據(jù)同步服務(wù),但由于網(wǎng)站空間服務(wù)供應(yīng)商不提供遠(yuǎn)程連接MYSql,所以無法利用NaviCat客戶端通過填寫服務(wù)器地址來連接遠(yuǎn)程服務(wù)器,在網(wǎng)上找到了SSH方式連接,但經(jīng)過測(cè)試后發(fā)現(xiàn)依舊無法連接。
    2011-08-08
  • MySQL導(dǎo)入導(dǎo)出助手類庫MysqlHelper安裝使用

    MySQL導(dǎo)入導(dǎo)出助手類庫MysqlHelper安裝使用

    這篇文章主要為大家介紹了MySQL導(dǎo)入導(dǎo)出助手類庫MysqlHelper安裝使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • 詳解MySQL中表的內(nèi)外連接

    詳解MySQL中表的內(nèi)外連接

    這篇文章主要為大家介紹了MySQL中表的內(nèi)外連接的相關(guān)知識(shí),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • MySQL自增ID用完的幾種解決方案

    MySQL自增ID用完的幾種解決方案

    MySQL的自增ID(AUTO_INCREMENT)用完之后,會(huì)出現(xiàn)重復(fù)ID的問題,那么如何解決這個(gè)問題呢,接下本文就給大家介紹MySQL自增ID用完的幾種解決方案,需要的朋友可以參考下
    2023-07-07

最新評(píng)論