成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

最快速的辦法解決MySQL數據量增大之后翻頁慢問題

數據庫 MySQL
MySQL單表數據量超過30萬后,使用Limit翻頁查詢時 越往后翻頁性能越慢。

最快速的辦法解決MySQL數據量增大之后翻頁慢問題

MySQL最易碰到的性能問題就是數據量逐步增大之后的翻頁速度變慢的額問題,而且越往后翻頁速度越慢,如果用最快速的辦法解決,以下就是解決辦法,簡單方便。

1、問題現狀

現有MySQL數據表 event_data ,數據量 36.7萬,如下:

 

  1. mysql> select count(1) from event_data; 

  2. +----------+ 

  3. count(1) | 

  4. +----------+ 

  5. |   367961 | 

  6. +----------+ 

  7. 1 row in set (0.05 sec) 

使用SQL-Limit分頁查詢,需要花費時間382秒,如下:

 

  1.   SELECT a.* 

  2.     FROM event_data a 

  3.    WHERE a.receive_time >= '2018-03-28 00:00:00' 

  4.      AND a.receive_time <= '2018-03-28 23:59:59' 

  5. ORDER BY a.receive_time DESC 

  6.    LIMIT 56280,15; 

其中 receive_time  字段已建立索引,event_data 表的主鍵字段為 pk_id。 

2、問題分析

但是如果把上面的SQL稍微變動一下,就會發現查詢速度有質的飛躍,如下:

 

  1. mysql>    SELECT a.pk_id 

  2.     ->      FROM event_data a 

  3.     ->     WHERE a.receive_time >= '2018-03-28 00:00:00' 

  4.     ->       AND a.receive_time <= '2018-03-28 23:59:59' 

  5.     ->  ORDER BY a.receive_time DESC 

  6.     ->     LIMIT 56280,15; 

  7. +----------------------------------+ 

  8. | pk_id                            | 

  9. +----------------------------------+ 

  10. | ce7d990f39a4411c88ebb3240497e6f3 | 

  11. | bd47b1c380c946c39b3ec172a262823f | 

  12. | c1820a5633714a5e9a0b0c2abb092579 | 

  13. | d58456cbe16d4cc4a20645c1126fb9b7 | 

  14. | a1d786640ea048a7bd10bd9f12868d6d | 

  15. | f590aa4f26034dd9af2f4ba0d4f7430c | 

  16. | af3e81eb43b84467bd3e2c7ad31d6aff | 

  17. | 3ee331dce2064a788515986a0a97ac2b | 

  18. | 46f462dc4209499f90dad2dc4076e4ca | 

  19. | 8ebb7ff55bc443e4854e583f6dc37ff7 | 

  20. | 883fd68d93dc49eab5b35ebf9ab8f8ee | 

  21. | 932c264d6dd140f3ac4f07f3410ce147 | 

  22. | 19b6426cdd664fe2983166e0cca93c53 | 

  23. | 3a0bfa4e000e4b69bba1a6bed6545973 | 

  24. | 5640a162380346f19d57a61c1dc0dd42 | 

  25. +----------------------------------+ 

  26. 15 rows in set (0.03 sec) 

查詢結果返回只需要30毫秒,雖然SQL變動很小,只是將查詢結果 由 a.* 改為了 a.pk_id,但是速度的提升是巨大的。

原因分析:兩條SQL where 條件語句都是使用了索引的,這里沒有問題,但是查詢結果不同,利用了索引查詢的語句中如果只包含了那個索引列(覆蓋索引),那么這種情況會查詢很快,這里就是這種情況。

利用覆蓋索引,將查詢語句需要掃描表的行數降低到最少,即可降低查詢時間。

3、問題解決

按照上面的分析,我們使用表連接的情況實現SQL優化,如下:

 

  1. select a.* FROM (  
  2.             SELECT pk_id   
  3.               FROM event_data c   
  4.              WHERE c.receive_time >= '2018-03-28 00:00:00'   
  5.                AND c.receive_time <= '2018-03-28 23:59:59'   
  6.                     ORDER BY c.receive_time DESC   
  7.              LIMIT 56280,15  
  8.                 ) b   
  9.       left join event_data a   
  10.              on a.pk_id=b.pk_id 

執行時間為0.048秒,達到優化目標。 

責任編輯:龐桂玉 來源: Oo若離oO的博客
相關推薦

2021-04-07 10:20:31

MySQL數據庫命令

2020-07-19 10:53:42

數據庫MySQL遷移

2011-08-16 09:21:30

MySQL大數據量快速語句優化

2018-05-15 08:44:44

TensorFlowKeras內存

2024-07-04 13:42:12

2011-01-19 17:54:48

2020-06-15 08:06:25

ES數據

2009-12-08 15:19:58

WCF大數據量

2017-11-22 15:33:56

MySQL快速插入語句優化

2024-01-23 12:56:00

數據庫微服務MySQL

2024-01-29 08:45:38

MySQL大數據分頁

2018-09-06 16:46:33

數據庫MySQL分頁查詢

2018-07-04 14:56:02

HTTP傳輸編碼

2010-03-02 16:43:46

2015-03-09 10:40:44

MySQL大量數據插入

2010-05-17 17:45:54

MySQL亂碼問題

2009-12-08 09:21:13

WCF數據量

2021-01-07 07:46:34

MyBatis 數據量JDBC

2010-04-19 14:57:16

Oracle收縮表分區

2011-03-03 10:32:07

Mongodb億級數據量
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩性生活网 | 草草视频在线播放 | 91精品国产91久久久久久不卞 | 精品成人一区二区 | 国产成人精品一区二区三区 | www.黄色网| 性色av网站 | 狠狠艹 | 天天曰夜夜操 | 国产91久久久久蜜臀青青天草二 | 久久久精品视频免费看 | 色综合色综合 | 欧美日韩国产免费 | 亚洲视频免费在线观看 | 中文在线观看视频 | 一级黄色在线 | 亚洲视频一区在线观看 | 2019精品手机国产品在线 | 国产免费拔擦拔擦8x高清 | 欧美日韩不卡合集视频 | 久久人人网 | 欧美精品福利 | 国产资源在线观看 | 伊人久久大香线 | 青久草视频 | 成人深夜福利 | 草久久久 | 国产欧美一区二区三区久久 | 欧美性生交大片免费 | a爱视频 | 欧美日韩一区精品 | 网站国产| 最新av在线网址 | 中文字幕亚洲区一区二 | 亚洲国产aⅴ成人精品无吗 综合国产在线 | 亚洲视频一区在线观看 | 狠狠爱综合网 | 浴室洗澡偷拍一区二区 | 日韩精品在线网站 | 国产一级片免费看 | 亚洲精品乱码久久久久久按摩观 |