同樣是取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,...