日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

InnoDB与MyISAM中的count(*)的执行效率比较

發布時間:2024/9/20 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 InnoDB与MyISAM中的count(*)的执行效率比较 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

今天同學們在群里討論oracle的count(*)與count(1)的問題,正好提到mysql的情況。我突然想到自己遇到的問題:在myisam引擎執行count(*)速度非常快,而且執行速度與記錄條數無關,而innodb卻不是這樣,記錄越多,速度越慢。?

??? 于是做了一個實驗,在一個有8000W條記錄的innodb表執行了一下 select count(*) from table 。 果然一直等待,大概8分多后出來結果。馬上再次執行相同的語句,用時大約22秒。馬上執行第三次,還是約22秒。?

??? 于是我猜想innodb沒有把記錄數保存起來,而是做了實時統計,所以導致速度比較慢。第二次、第三次相對較快是因為高速緩存的原因。于是打電話咨詢DBA同學。經過DBA同學的專業解答,我明白了:我猜對了,呵呵。所以,以后要注意在innodb中count(*)的問題,盡量避免吧……除非能確保該表始終保持很少的記錄數。?

??? 另外,在網上查了一些資料:?

???

引用


InnoDB Pitfalls?
However, all is not rosy with InnoDB. Because of its transactional nature, it has bottlenecks of its own. On MyISAM, doing a query that does SELECT COUNT(*) FROM {some_table}, is very fast, since MyISAM keeps the information in the index.?

On InnoDB, this info is not stored in an index, and even the index and the data are kept in the same file. So, doing the same query on a table can incur a significant performance penalty.?

To check what overhead this has, I wrote a simple test benchmark code. I duplicated a client node table that has 20,243 rows from MyISAM to InnoDB.?

On a quiescent AMD 64 machine with MySQL server 5.0.24, doing a SELECT COUNT(*) FROM node takes 0.835 milliseconds on MyISAM, while on InnoDB it takes 12.292 milliseconds!?



記錄一下,innodb引擎的count(*)問題。

來源:https://blog.csdn.net/gsls181711/article/details/46784655

總結

以上是生活随笔為你收集整理的InnoDB与MyISAM中的count(*)的执行效率比较的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。