国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

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

2024-07-24 12:48:04
字體:
供稿:網(wǎng)友

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這個最短的二級索引。可能有人會問為啥不用更短的主鍵索引【int類型】呢,這主要是因為innodb存儲引擎下,主鍵索引實質(zhì)包含了索引和數(shù)據(jù),掃描主鍵索引實際是掃描物理記錄,代價實質(zhì)是最大的。再來看看幾種select count(col_name), count(group_id)使用了最短二級索引,因為該列就是索引列;而count(user_id)則使用了組合索引,由于user_id實質(zhì)不能利用該索引,但掃描索引也能得到記錄數(shù),而且比掃描物理記錄代價小,這里應(yīng)該是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 count多個表的數(shù)據(jù)實例詳解MySQL中distinct和count(*)的使用方法比較詳細(xì)解讀MySQL中COUNT函數(shù)的用法MYSQL中統(tǒng)計查詢結(jié)果總行數(shù)的便捷方法省去count(*)淺析一個MYSQL語法(在查詢中使用count)的兼容性問題關(guān)于mysql中innodb的count優(yōu)化問題分享MySQL里的found_row()與row_count()的解釋及用法有關(guān)mysql中ROW_COUNT()的小例子關(guān)于mysql innodb count(*)速度慢的解決辦法Mysql中的count()與sum()區(qū)別詳細(xì)介紹mysql_num_rows VS COUNT 效率問題分析mysql count詳解及函數(shù)實例代碼
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 瑞金市| 安达市| 彩票| 慈溪市| 新平| 辽中县| 陕西省| 即墨市| 长岭县| 安康市| 东平县| 衡阳市| 故城县| 乐业县| 鲜城| 泉州市| 荣昌县| 驻马店市| 百色市| 广东省| 邻水| 玉林市| 吉安县| 翁牛特旗| 江口县| 双鸭山市| 霍城县| 泰顺县| 巴楚县| 潜山县| 新乐市| 泰州市| 桂东县| 盱眙县| 南雄市| 苍梧县| 通海县| 弥勒县| 石柱| 黔东| 商水县|