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

Mysql高效分頁(yè)詳解

 更新時(shí)間:2017年01月19日 08:31:22   作者:zsl10  
這篇文章主要為大家詳細(xì)介紹了Mysql高效分頁(yè)的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

前言

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

基本分頁(yè)技巧

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

1、字段排序

ORDER BY a 
ORDER BY a,b
ORDER 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、下面查詢是無(wú)法使用以上索引的

ORDER BY a ASC, b DESC, c DESC//排序方向不一致
WHERE g = const ORDER BY b, c // 字段g不是索引一部分
WHERE a = const ORDER BY c //沒(méi)有使用字段b 
WHERE a = const ORDER BY a, d // 字段d不是索引的一部分 

解決大數(shù)據(jù)量翻頁(yè)問(wèn)題

1、將LIMIT M,N的查詢改為L(zhǎng)IMIT N
例如,使用LIMIT 10000,20,Mysql將需要讀取前10000行,然后獲取后面的20行 ,這是非常低效的,使用LIMIT N的方式,通過(guò)每頁(yè)第一條或最后一條記錄的id來(lái)做條件篩選,再配合降序和升序獲得上/下一頁(yè)的結(jié)果集 。
2、限制用戶翻頁(yè)數(shù)量
產(chǎn)品實(shí)際使用過(guò)程中用戶很少關(guān)心搜索結(jié)果的第1萬(wàn)條數(shù)據(jù)。
3、使用延遲關(guān)聯(lián)
通過(guò)使用覆蓋索引來(lái)查詢返回需要的主鍵,再根據(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>);

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • mysql的事務(wù),隔離級(jí)別和鎖用法實(shí)例分析

    mysql的事務(wù),隔離級(jí)別和鎖用法實(shí)例分析

    這篇文章主要介紹了mysql的事務(wù),隔離級(jí)別和鎖用法,結(jié)合實(shí)例形式分析了MySQL事務(wù),隔離級(jí)別和鎖相關(guān)原理、用法及操作注意事項(xiàng),需要的朋友可以參考下
    2020-02-02
  • 數(shù)據(jù)庫(kù)管理中19個(gè)MySQL優(yōu)化方法

    數(shù)據(jù)庫(kù)管理中19個(gè)MySQL優(yōu)化方法

    小編給大家總結(jié)了19條非常實(shí)用的MySQL數(shù)據(jù)庫(kù)優(yōu)化方法,這是每個(gè)服務(wù)器管理人員都必須知道的,一起學(xué)習(xí)下。
    2017-11-11
  • MYSQL中查詢LONGBLOB類型數(shù)據(jù)的大小的詳細(xì)示例

    MYSQL中查詢LONGBLOB類型數(shù)據(jù)的大小的詳細(xì)示例

    在MySQL中,LONGBLOB?是一種二進(jìn)制大對(duì)象(BLOB)數(shù)據(jù)類型,用于存儲(chǔ)大量的二進(jìn)制數(shù)據(jù),但是,LONGBLOB?數(shù)據(jù)類型本身并不直接存儲(chǔ)數(shù)據(jù)的大?。ㄩL(zhǎng)度),它存儲(chǔ)的是二進(jìn)制數(shù)據(jù)的實(shí)際內(nèi)容,這篇文章主要介紹了MYSQL中怎么查詢LONGBLOB類型數(shù)據(jù)的大小,需要的朋友可以參考下
    2024-06-06
  • Win10安裝MySQL5.7.18winX64 啟動(dòng)服務(wù)器失敗并且沒(méi)有錯(cuò)誤提示

    Win10安裝MySQL5.7.18winX64 啟動(dòng)服務(wù)器失敗并且沒(méi)有錯(cuò)誤提示

    這篇文章主要介紹了Win10安裝MySQL5.7.18winX64 啟動(dòng)服務(wù)器失敗并且沒(méi)有錯(cuò)誤提示,需要的朋友可以參考下
    2017-06-06
  • CentOS7下 MySQL定時(shí)自動(dòng)備份的實(shí)現(xiàn)方法

    CentOS7下 MySQL定時(shí)自動(dòng)備份的實(shí)現(xiàn)方法

    這篇文章主要介紹了CentOS7 下MySQL定時(shí)自動(dòng)備份的實(shí)現(xiàn)方法,主要實(shí)現(xiàn)了數(shù)據(jù)庫(kù)備份,清理過(guò)期備份文件功能,需要的朋友可以參考下
    2019-12-12
  • MySQL 5.7.16 修改密碼提示 ERROR 1054 (42S22): Unknown column ''''password'''' in ''''field list''''的原因

    MySQL 5.7.16 修改密碼提示 ERROR 1054 (42S22): Unknown column ''''p

    這篇文章主要介紹了MySQL 5.7.16 修改密碼提示 ERROR 1054 (42S22): Unknown column 'password' in 'field list'的原因分析及解決辦法,需要的朋友可以參考下
    2017-01-01
  • MySQL 編碼機(jī)制

    MySQL 編碼機(jī)制

    一般在MYSQL使用中文查詢 都是用 set NAMES character
    2008-12-12
  • 關(guān)于Mysql子查詢的三個(gè)應(yīng)用場(chǎng)景

    關(guān)于Mysql子查詢的三個(gè)應(yīng)用場(chǎng)景

    這篇文章主要介紹了關(guān)于Mysql子查詢的三個(gè)應(yīng)用場(chǎng)景,子查詢是在一個(gè)完整的查詢語(yǔ)句中,嵌套不同功能的小查詢,從而完成復(fù)雜查詢的一種編寫(xiě)形式,需要的朋友可以參考下
    2023-07-07
  • MySQL使用命令行備份數(shù)據(jù)的方法詳解

    MySQL使用命令行備份數(shù)據(jù)的方法詳解

    由于長(zhǎng)期使用測(cè)試環(huán)境的數(shù)據(jù)庫(kù),時(shí)不時(shí)會(huì)有臟數(shù)據(jù)刪除不干凈,對(duì)此很需要一個(gè)實(shí)時(shí)將生產(chǎn)庫(kù)的數(shù)據(jù)定期備份一份,防止生產(chǎn)庫(kù)中會(huì)有臟數(shù)據(jù)進(jìn)來(lái),所以本文給大家介紹了MySQL使用命令行備份數(shù)據(jù)的方法,需要的朋友可以參考下
    2024-02-02
  • 手把手教你MySQL運(yùn)算符

    手把手教你MySQL運(yùn)算符

    運(yùn)算符是告訴MySQL執(zhí)行特定算數(shù)或邏輯操作的符號(hào),下面這篇文章主要給大家介紹了關(guān)于MySQL運(yùn)算符的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-03-03

最新評(píng)論