自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

MySQL innodb引擎中小心count(*)陷阱

數(shù)據(jù)庫 MySQL
我們今天主要向大家描述的是MySQL innodb引擎中的count(*)陷阱,以下就是具體方案的描述,希望在你今后的學(xué)習(xí)中會有所幫助。

以下的文章主要描述的是MySQL innodb引擎中的count(*)陷阱,你如果對MySQL innodb引擎中的count(*)陷阱有興趣的話你就可以點擊以下的文章進行觀看了。希望會給你帶來一些幫助在此方面。

word引起MySQL數(shù)據(jù)庫崩潰?

InnoDB delete from xxx速度暴慢原因

MySQL Storage Engine 小記

推薦圈子: JBPM @net

更多相關(guān)推薦 今天同學(xué)們在群里討論oracle的count(*)與count(1)的問題,正好提到MySQL的情況。我突然想到自己遇到的問題:在myisam引擎執(zhí)行count(*)速度非??欤覉?zhí)行速度與記錄條數(shù)無關(guān),而MySQL innodb卻不是這樣,記錄越多,速度越慢。

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

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

另外,在網(wǎng)上查了一些資料:

引用

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!

 

以上就是對MySQL innodb引擎的count(*)問題的描述。

【編輯推薦】

  1. MySQL內(nèi)核正確的編譯操作流程
  2. 對MySQL安全配置的匯總
  3. MySQL數(shù)據(jù)庫的可視化管理工具介紹
  4. MySQL Table is read only的具體解決方案
  5. MySQL字符的編碼轉(zhuǎn)換問題詳解


     
責(zé)任編輯:佚名 來源: 博客園
相關(guān)推薦

2024-04-29 14:39:20

2010-08-05 09:27:03

Flex應(yīng)用

2019-06-11 16:11:16

MySQLMyISAMInnoDB

2010-05-21 16:23:52

MySQL MyISA

2010-11-23 11:27:53

MySQL MyISA

2010-05-11 15:06:24

MySQL MyISA

2017-12-14 21:30:05

MySQLInnoDBIO子系統(tǒng)

2024-06-20 13:38:03

2017-12-15 10:20:56

MySQLInnoDB同步機制

2009-05-05 10:19:37

存儲引擎InnoDBMyISAM

2018-06-14 10:44:59

MySQLMyISAMInnoDB

2011-03-07 10:10:35

MySQL處理空值

2010-05-21 16:10:28

2015-10-29 13:44:06

MySQLinnodb引擎備份

2022-12-14 07:32:40

InnoDBMySQL引擎

2009-11-02 11:18:09

qq盜號

2009-12-22 20:45:00

圣誕購物釣魚網(wǎng)站

2009-05-19 09:58:41

MyISAMInnoDB存儲引擎

2011-07-27 09:33:16

MySQL數(shù)據(jù)庫INNODB數(shù)據(jù)庫引擎

2016-10-10 23:01:48

安全認(rèn)證云供應(yīng)商安全評估
點贊
收藏

51CTO技術(shù)棧公眾號