mysql中count(1)與count(*)比較

chenfeng發表於2016-04-07

count詳解:
count(*)將返回表格中所有存在的行的總數包括值為null的行,然而count(列名)將返回表格中除去null以外的所有行的總數(有預設值的列也會被計入).
distinct 列名,得到的結果將是除去值為null和重複資料後的結果

sql調優,主要是考慮降低:consistent gets和physical reads的數量。
count(1)與count(*)比較:
如果你的資料表沒有主鍵,那麼count(1)比count(*)快
如果有主鍵的話,那主鍵(聯合主鍵)作為count的條件也比count(*)要快
如果你的表只有一個欄位的話那count(*)就是最快的啦
count(*) count(1) 兩者比較。主要還是要count(1)所相對應的資料欄位。
如果count(1)是聚索引,id,那肯定是count(1)快。但是差的很小的。
因為count(*),自動會最佳化指定到那一個欄位。所以沒必要去count(?),用count(*),sql會幫你完成最佳化的

總結三條經驗
1.任何情況下SELECT COUNT(*) FROM tablename是最優選擇;
2.儘量減少SELECT COUNT(*) FROM tablename WHERE COL = 'value’ 這種查詢;
3.杜絕SELECT COUNT(COL) FROM tablename的出現。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/15498/viewspace-2076594/,如需轉載,請註明出處,否則將追究法律責任。

相關文章