《Mysql應用mysql技巧之select count的區別分析》要點:
本文介紹了Mysql應用mysql技巧之select count的區別分析,希望對您有用。如果有疑問,可以聯系我們。
1.測試環境MYSQL教程
OS:Linux
DB:mysql-5.5.18
table:innodb存儲引擎MYSQL教程
表定義如下:MYSQL教程
MYSQL教程
2.?測試場景與分析【統計表group_message的記錄數目】MYSQL教程
(1)select count(*)方式MYSQL教程
MYSQL教程
(2)select count(1)方式MYSQL教程
MYSQL教程
(3)select count(col_name)方式MYSQL教程
分別使用MYSQL教程
select count(group_id)MYSQL教程
select count(user_id)MYSQL教程
select count(col_null)MYSQL教程
MYSQL教程
? ? ?通過上述測試結果可以看到,select count(*)和select count(1)都使用了group_id這個最短的二級索引.可能有人會問為啥不用更短的主鍵索引【int類型】呢,這主要是因為innodb存儲引擎下,主鍵索引實質包含了索引和數據,掃描主鍵索引實際是掃描物理記錄,代價實質是最大的.再來看看幾種select count(col_name), count(group_id)使用了最短二級索引,因為該列就是索引列;而count(user_id)則使用了組合索引,由于user_id實質不能利用該索引,但掃描索引也能得到記錄數,而且比掃描物理記錄代價小,這里應該是mysql的一個優化;count(col_null)則不能使用索引,因為該列含有null值,所以效率最低.另外,對于含有null值的行,count(col_null)實際不會統計,這會與你想統計表記錄數目的初衷不符,比如測試表有852226條記錄,但col_null列只有1行非空,則統計結果如下:MYSQL教程
MYSQL教程
3.測試結論MYSQL教程
mysql中,需要通過selct count 統計表記錄數目時,使用count(*)或count(1)就好.MYSQL教程
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/3264.html