mysql技巧之select count的區(qū)別分析
1.測(cè)試環(huán)境
OS:Linux
DB:mysql-5.5.18
table:innodb存儲(chǔ)引擎
表定義如下:
2. 測(cè)試場(chǎng)景與分析【統(tǒng)計(jì)表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)
通過(guò)上述測(cè)試結(jié)果可以看到,select count(*)和select count(1)都使用了group_id這個(gè)最短的二級(jí)索引。可能有人會(huì)問(wèn)為啥不用更短的主鍵索引【int類型】呢,這主要是因?yàn)閕nnodb存儲(chǔ)引擎下,主鍵索引實(shí)質(zhì)包含了索引和數(shù)據(jù),掃描主鍵索引實(shí)際是掃描物理記錄,代價(jià)實(shí)質(zhì)是最大的。再來(lái)看看幾種select count(col_name), count(group_id)使用了最短二級(jí)索引,因?yàn)樵摿芯褪撬饕?;而count(user_id)則使用了組合索引,由于user_id實(shí)質(zhì)不能利用該索引,但掃描索引也能得到記錄數(shù),而且比掃描物理記錄代價(jià)小,這里應(yīng)該是mysql的一個(gè)優(yōu)化;count(col_null)則不能使用索引,因?yàn)樵摿泻衝ull值,所以效率最低。另外,對(duì)于含有null值的行,count(col_null)實(shí)際不會(huì)統(tǒng)計(jì),這會(huì)與你想統(tǒng)計(jì)表記錄數(shù)目的初衷不符,比如測(cè)試表有852226條記錄,但col_null列只有1行非空,則統(tǒng)計(jì)結(jié)果如下:
3.測(cè)試結(jié)論
mysql中,需要通過(guò)selct count 統(tǒng)計(jì)表記錄數(shù)目時(shí),使用count(*)或count(1)就好。
- MySQL select、insert、update批量操作語(yǔ)句代碼實(shí)例
- 解決MySQL讀寫(xiě)分離導(dǎo)致insert后select不到數(shù)據(jù)的問(wèn)題
- MySQL將select結(jié)果執(zhí)行update的實(shí)例教程
- MySQL之select、distinct、limit的使用
- 為什么MySQL不建議使用SELECT?*
- MySQL運(yùn)行報(bào)錯(cuò):“Expression?#1?of?SELECT?list?is?not?in?GROUP?BY?clause?and?contains?nonaggre”解決方法
- MySQL select count(*)計(jì)數(shù)很慢優(yōu)化方案
相關(guān)文章
Mysql實(shí)現(xiàn)定時(shí)清空一張表的舊數(shù)據(jù)并保留幾條數(shù)據(jù)(推薦)
這篇文章主要介紹了Mysql實(shí)現(xiàn)定時(shí)清空一張表的舊數(shù)據(jù)并保留幾條數(shù)據(jù),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12Mysql中時(shí)間戳轉(zhuǎn)為Date的方法示例
這篇文章主要給大家介紹了關(guān)于Mysql中時(shí)間戳轉(zhuǎn)為Date的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11mysql中int、bigint、smallint 和 tinyint的區(qū)別詳細(xì)介紹
最近使用mysql數(shù)據(jù)庫(kù)的時(shí)候遇到了多種數(shù)字的類型,主要有int,bigint,smallint和tinyint;接下來(lái)將詳細(xì)介紹以上三種類型的應(yīng)用2012-11-11MySQL中主鍵為0與主鍵自排約束的關(guān)系詳解(細(xì)節(jié))
這篇文章主要給大家介紹了關(guān)于MySQL中主鍵為0與主鍵自排約束的關(guān)系的相關(guān)資料,主要介紹的是其中的一些非常細(xì)的細(xì)節(jié),對(duì)大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-05-05