mysql技巧之select count的區(qū)別分析
1.測試環(huán)境
OS:Linux
DB:mysql-5.5.18
table:innodb存儲引擎
表定義如下:
2. 測試場景與分析【統(tǒng)計表group_message的記錄數(shù)目】
(1)select count(*)方式
(2)select count(1)方式
(3)select count(col_name)方式
分別使用
select count(group_id)
select count(user_id)
select count(col_null)
通過上述測試結(jié)果可以看到,select count(*)和select count(1)都使用了group_id這個最短的二級索引??赡苡腥藭枮樯恫挥酶痰闹麈I索引【int類型】呢,這主要是因為innodb存儲引擎下,主鍵索引實質(zhì)包含了索引和數(shù)據(jù),掃描主鍵索引實際是掃描物理記錄,代價實質(zhì)是最大的。再來看看幾種select count(col_name), count(group_id)使用了最短二級索引,因為該列就是索引列;而count(user_id)則使用了組合索引,由于user_id實質(zhì)不能利用該索引,但掃描索引也能得到記錄數(shù),而且比掃描物理記錄代價小,這里應該是mysql的一個優(yōu)化;count(col_null)則不能使用索引,因為該列含有null值,所以效率最低。另外,對于含有null值的行,count(col_null)實際不會統(tǒng)計,這會與你想統(tǒng)計表記錄數(shù)目的初衷不符,比如測試表有852226條記錄,但col_null列只有1行非空,則統(tǒng)計結(jié)果如下:
3.測試結(jié)論
mysql中,需要通過selct count 統(tǒng)計表記錄數(shù)目時,使用count(*)或count(1)就好。
相關文章
Mysql實現(xiàn)定時清空一張表的舊數(shù)據(jù)并保留幾條數(shù)據(jù)(推薦)
這篇文章主要介紹了Mysql實現(xiàn)定時清空一張表的舊數(shù)據(jù)并保留幾條數(shù)據(jù),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12mysql中int、bigint、smallint 和 tinyint的區(qū)別詳細介紹
最近使用mysql數(shù)據(jù)庫的時候遇到了多種數(shù)字的類型,主要有int,bigint,smallint和tinyint;接下來將詳細介紹以上三種類型的應用2012-11-11MySQL中主鍵為0與主鍵自排約束的關系詳解(細節(jié))
這篇文章主要給大家介紹了關于MySQL中主鍵為0與主鍵自排約束的關系的相關資料,主要介紹的是其中的一些非常細的細節(jié),對大家學習或者使用mysql具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-05-05