欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql技巧之select count的區(qū)別分析

 更新時間:2013年08月19日 22:09:19   作者:  
在工作過程中,時不時會有開發(fā)咨詢幾種select count()的區(qū)別,我總會告訴他們使用select count(*) 就好。下文我會展示幾種sql的執(zhí)行計(jì)劃來說明為啥是這樣。

1.測試環(huán)境

OS:Linux
DB:mysql-5.5.18
table:innodb存儲引擎

表定義如下:

2. 測試場景與分析【統(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)

     通過上述測試結(jié)果可以看到,select count(*)和select count(1)都使用了group_id這個最短的二級索引??赡苡腥藭枮樯恫挥酶痰闹麈I索引【int類型】呢,這主要是因?yàn)閕nnodb存儲引擎下,主鍵索引實(shí)質(zhì)包含了索引和數(shù)據(jù),掃描主鍵索引實(shí)際是掃描物理記錄,代價(jià)實(shí)質(zhì)是最大的。再來看看幾種select count(col_name), count(group_id)使用了最短二級索引,因?yàn)樵摿芯褪撬饕?;而count(user_id)則使用了組合索引,由于user_id實(shí)質(zhì)不能利用該索引,但掃描索引也能得到記錄數(shù),而且比掃描物理記錄代價(jià)小,這里應(yīng)該是mysql的一個優(yōu)化;count(col_null)則不能使用索引,因?yàn)樵摿泻衝ull值,所以效率最低。另外,對于含有null值的行,count(col_null)實(shí)際不會統(tǒng)計(jì),這會與你想統(tǒng)計(jì)表記錄數(shù)目的初衷不符,比如測試表有852226條記錄,但col_null列只有1行非空,則統(tǒng)計(jì)結(jié)果如下:

3.測試結(jié)論

mysql中,需要通過selct count 統(tǒng)計(jì)表記錄數(shù)目時,使用count(*)或count(1)就好。

相關(guān)文章

  • Mysql實(shí)現(xiàn)定時清空一張表的舊數(shù)據(jù)并保留幾條數(shù)據(jù)(推薦)

    Mysql實(shí)現(xiàn)定時清空一張表的舊數(shù)據(jù)并保留幾條數(shù)據(jù)(推薦)

    這篇文章主要介紹了Mysql實(shí)現(xiàn)定時清空一張表的舊數(shù)據(jù)并保留幾條數(shù)據(jù),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • 一條sql語句完成MySQL去重留一

    一條sql語句完成MySQL去重留一

    在使用mysql時,有時需要查詢出某個字段不重復(fù)的記錄,雖然mysql提供 有distinct這個關(guān)鍵字來過濾掉多余的重復(fù)記錄只保留一條,但往往只用它來返回不重復(fù)記錄的條數(shù),而不是用它來返回不重記錄的所有值。
    2017-12-12
  • Mysql中時間戳轉(zhuǎn)為Date的方法示例

    Mysql中時間戳轉(zhuǎn)為Date的方法示例

    這篇文章主要給大家介紹了關(guān)于Mysql中時間戳轉(zhuǎn)為Date的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • mysql中int、bigint、smallint 和 tinyint的區(qū)別詳細(xì)介紹

    mysql中int、bigint、smallint 和 tinyint的區(qū)別詳細(xì)介紹

    最近使用mysql數(shù)據(jù)庫的時候遇到了多種數(shù)字的類型,主要有int,bigint,smallint和tinyint;接下來將詳細(xì)介紹以上三種類型的應(yīng)用
    2012-11-11
  • mysql索引失效的五種情況分析

    mysql索引失效的五種情況分析

    這篇文章主要介紹了mysql索引失效的5種情況分析,需要的朋友可以參考下
    2015-01-01
  • mysql主從只同步部分庫或表的思路與方法

    mysql主從只同步部分庫或表的思路與方法

    mysql主從搭建后默認(rèn)同步所有庫,同步原理是通過二進(jìn)制日志方式傳輸,下面這篇文章主要給大家介紹了關(guān)于mysql主從只同步部分庫或表的思路與方法,需要的朋友可以參考下
    2022-06-06
  • asp采用ODBC接口訪問MySQL的方法

    asp采用ODBC接口訪問MySQL的方法

    asp采用ODBC接口訪問MySQL的方法...
    2007-07-07
  • MySQL中主鍵為0與主鍵自排約束的關(guān)系詳解(細(xì)節(jié))

    MySQL中主鍵為0與主鍵自排約束的關(guān)系詳解(細(xì)節(jié))

    這篇文章主要給大家介紹了關(guān)于MySQL中主鍵為0與主鍵自排約束的關(guān)系的相關(guān)資料,主要介紹的是其中的一些非常細(xì)的細(xì)節(jié),對大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-05-05
  • MySQL隔離級別和鎖機(jī)制的深入講解

    MySQL隔離級別和鎖機(jī)制的深入講解

    這篇文章主要給大家介紹了關(guān)于MySQL隔離級別和鎖機(jī)制的相關(guān)資料,主要包括深入理解MySQL隔離級別和鎖機(jī)制使用實(shí)例、應(yīng)用技巧、基本知識點(diǎn)總結(jié)和需要注意事項(xiàng),需要的朋友可以參考下
    2021-08-08
  • 全面解析Windows下安裝 mysql5.7的方法

    全面解析Windows下安裝 mysql5.7的方法

    這篇文章主要介紹了全面解析Windows下安裝 mysql5.7的方法的相關(guān)資料,需要的朋友可以參考下
    2016-07-07

最新評論