php下MYSQL limit的優化

2022-10-04 06:00:16 字數 1083 閱讀 5586

同樣是取10條資料

select * from yanxue8_visit limit 10000,10 

和select&nbs from yanxue8_visit limit 0,10

就不是乙個數量級別的。 

&www.cppcns.comnbsp;網上也很多關於limit的五條優化準則,都是翻譯自mysql手冊,雖然正確但不實用。今天發現一篇文章寫了些關於limit優化的,很不錯。原文位址:

文中不是直接使用limit,而是首先獲取到offset的id然後直接使用limit size來獲取資料。根據他的資料,明顯要www.cppcns.com好於直接使用limit。這裡我具體使用資料分兩種情況進行測試。(測試環境win2033+p4雙核(3ghz) +4g記憶體 mysql 5.0.19)

1、offset比較小的時候。 

select * from yanxue8_visit limit 10,10 

多次執行,時間保持在0.0004-0.0005之間 

select * from yanxue8_visit where vid >=(

select vid from yanxue8_visit order by vid limit 10,1

) limit 10 

多次執行,時間保持在0.0005-0.0006之間,主要是0.0006

結論:偏移offset較小的時候,直接使用limit較優。這個顯然是子查詢的原因。

2、offset大的時候。 

select * from yanxue8_visit limit 10000,10 

多次執行,時間保持在0.0187左右 

hxgnuvlmselect * from yanxue8_visit where vid >=(

select vid from yanxue8_visit order by&程式設計客棧nbsp;vid limit 10000,1

) limit 10

多次執行,時間保持在0.0061左右,只有前者的1/3。可以預計offset越大,後者越優。 

本文標題: php下mysql limit的優化

本文位址:

MySQL limit 的 優化 原理 ?

mysql limit 分頁 優化網上有很多的優化方案,一些確實能夠提高幾倍乃至數百倍的效能優化。至於是哪些方案本文不進行描述了,搜尋引擎一搜就出來了很多優秀的文章。本文主要來進行思考那些limit 優化到底是如何優化的,從mysql的執行計畫來分析。mysql 執行計畫 explain 關鍵字 e...

MySQL limit用法,分頁的實現。

mysql 分頁 select from tablename where 條件limit 當前頁碼 頁面容量 1,頁面容量 mysql中limit的用法 在我們使用查詢語句的時候,經常要返回前幾條或者中間某幾行資料,這個時候怎麼辦呢?不用擔心,mysql已經為我們提供了這樣乙個功能。select f...

關於Mysql limit 的效能優化

問題 mysql 的 limit 給分頁帶來了極大的方便,但資料偏移量一大,limit 的效能就急劇下降。以下是兩條查詢語句,都是取10條資料,但效能就相去甚遠。select from table name limit 10000,10 select from table name limit 0,...