mysql limit 語句在大數據量時候,limit後的偏移量過大,第一次查詢會特別慢,由於mysql默認是開啓查詢緩存的,因此,對於第二次再次執行大偏移查詢不會有影響。 mysql
示例:100萬的一個表,id作主鍵,auto_increment。 sql
須要查詢:SELECT * FROM table ORDER BY id DESC LIMIT 990000,100 緩存
比較慢。 大數據
常見的辦法是:SELECT * FROM table WHERE id >=(SELECT id FROM table ORDER BY id DESC LIMIT 990000,1) ORDER BY id DESC LIMIT 100 優化
id可能不連續,並且排序也可能不是隻依賴於id, 這種辦法基本上沒法在實際項目中應用。 排序
好比,咱們的實際項目中,有排序很是複雜的方式:ORDER BY (column1 + column2) * column3 DESC,等等這些方式,一百萬的數據,若是偏移量990000,那麼反過來的排序應該更接近頭部: rem
-------------------------------------------------------------------[99萬-|100條]--100萬 it
須要實現:SELECT * FROM table ORDER BY columns DESC LIMIT 990000, 100 table
推測出一種解決辦法:反向排序,而後截取頭部,再次反向,獲得結果: im
$head = max(100萬-99萬-100, 0 );
SELECT * FROM (SELECT * FROM table ORDER BY columns ASC LIMIT $head, 100 ) AS t ORDER BY columns DESC
優化完成,對於靠近末尾的,速度和開頭的同樣快,但若是取中間的偏移量,則沒有差異。