国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

聊聊MySQL的COUNT(*)的性能

瀏覽:13日期:2023-10-08 14:13:07

前言

基本職場上的程序員用來統計數據庫表的行數都會使用count(*),count(1)或者count(主鍵),那么它們之間的區別和性能你又是否了解呢?

其實程序員在開發的過程中,在一張大表上統計總行數是非常耗時的一個操作,那么我們應該用哪個方法統計會更快呢?

接下來我們就來聊一聊MySQL中統計總行數的方法和性能。

count(*),count(1),count(主鍵)哪個更快?

1、建表并且插入1000萬條數據進行實驗測試:

# 創建測試表CREATE TABLE `t6` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL, `status` tinyint(4) NOT NULL, PRIMARY KEY (`id`), KEY `idx_status` (`status`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;# 創建存儲過程插入1000w數據CREATE PROCEDURE insert_1000w()BEGIN DECLARE i INT; SET i=1; WHILE i<=10000000 DO INSERT INTO t6(name,status) VALUES(’god-jiang-666’,1); SET i=i+1; END WHILE;END;#調用存儲過程,插入1000萬行數據call insert_1000w();

2、分析實驗結果

# 花了0.572秒select count(*) from t6;

聊聊MySQL的COUNT(*)的性能

# 花了0.572秒select count(1) from t6;

聊聊MySQL的COUNT(*)的性能

# 花了0.580秒select count(id) from t6;

聊聊MySQL的COUNT(*)的性能

# 花了0.620秒select count(*) from t6 force index (primary);

聊聊MySQL的COUNT(*)的性能

從上面的實驗我們可以得出,count(*)和count(1)是最快的,其次是count(id),最慢的是count使用了強制主鍵的情況。

下面我們繼續測試一下它們各自的執行計劃:

explain select count(*) from t6;show warnings;

聊聊MySQL的COUNT(*)的性能

聊聊MySQL的COUNT(*)的性能

explain select count(1) from t6;show warnings;

聊聊MySQL的COUNT(*)的性能

聊聊MySQL的COUNT(*)的性能

explain select count(id) from t6;show warnings;

聊聊MySQL的COUNT(*)的性能

聊聊MySQL的COUNT(*)的性能

explain select count(*) from t6 force index (primary);show warnings;

聊聊MySQL的COUNT(*)的性能

聊聊MySQL的COUNT(*)的性能

從上面的實驗可以得出這三點:

count(*)被MySQL查詢優化器改寫成了count(0),并選擇了idx_status索引 count(1)和count(id)都選擇了idx_statux索引 加了force index(primary)之后,走了強制索引

這個idx_status就是相當于是二級輔助索引樹,目的就是為了說明: InnoDB在處理count(*)的時候,有輔助索引樹的情況下,會優先選擇輔助索引樹來統計總行數。

為了驗證count(*)會優先選擇輔助索引樹這個結論,我們繼續來看看下面的實驗:

# 刪除idx_status索引,繼續執行count(*)alter table t6 drop index idx_status;explain select count(*) from t6;

聊聊MySQL的COUNT(*)的性能

從以上實驗可以得出,刪除了idx_status這個輔助索引樹,count(*)就會選擇走主鍵索引。所以結論:count(*)會優先選擇輔助索引,假如沒有輔助索引的存在,就會走主鍵索引。

為什么count(*)會優先選擇輔助索引?

在MySQL5.7.18之前,InnoDB通過掃描聚集索引來處理count(*)語句。

從MySQL5.7.18開始,InnoDB通過遍歷最小的可用二級索引來處理count(*)語句。如果不存在二級索引,則掃描聚集索引。

新版本為何會使用二級索引來處理count(*)呢?

因為InnoDB二級索引樹的葉子節點上存放的是主鍵,而主鍵索引樹的葉子節點存放的是整行數據,所以二級索引樹比主鍵索引樹小。因此查詢優化器基于成本考慮,優先選擇的是二級索引。所以索引count(*)快于count(主鍵)。

總結

這篇文章的結論就是count(*)=count(1)>count(id)

為什么count(id)走了主鍵索引還會更慢呢?因為count(id)需要取出主鍵,然后判斷不為空,再累加,代價更高。

count(*)是會總計出所有NOT NULL和NULL的字段,而count(id)是不會統計NULL字段的,所以我們在建表的盡量使用NOT NULL并且給它一個默認是空即可。

最后,在以后總計數據庫表的總行數的時候,可以大膽的使用count(*)或者count(1)。

參考資料

《高性能MySQL》(第三版)第六章優化COUNT()查詢 《MySQL實戰45講》林曉斌

到此這篇關于聊聊MySQL的COUNT(*)的性能的文章就介紹到這了,更多相關MySQL COUNT(*)內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 日本在线国产 | 国产成人偷拍 | 亚洲欧美日韩在线观看二区 | 一级美国乱色毛片 | 久久久最新精品 | 成年女人毛片免费观看中文w | 在线一区免费视频播放 | 色视频在线观看视频 | va欧美| 手机看片国产精品 | 国产最新网站 | 一本一道波多野结衣456 | 永久黄网站色视频免费观看99 | 欧美在线一二三区 | 手机看片1024国产基地 | 新体操真 | 亚洲在线中文字幕 | 啪视| 俄罗斯极品美女毛片免费播放 | 看真人视频a级毛片 | 欧美视频在线观看免费精品欧美视频 | 性视频网站在线 | 日韩视频中文字幕 | 国产网站黄| 亚洲一区中文字幕 | 欧美性色生活片天天看99 | 日韩3级| 国产成人精品一区二区秒拍 | 欧美一级免费在线观看 | 国产手机看片 | 99久久精品国产自免费 | 九九视频在线观看视频 | 国产精品不卡 | 久久手机免费视频 | 东莞a级毛片 | 日本午夜高清视频 | 成人国产精品一级毛片视频 | 欧美性猛交xxx免费看人妖 | 成 人 黄 色 视频播放16 | 国产男女 爽爽爽爽视频 | 久久精品国产免费看久久精品 |