MySql統(tǒng)計(jì)函數(shù)COUNT的具體使用詳解
1. COUNT()函數(shù)概述
COUNT() 是一個(gè)聚合函數(shù),返回指定匹配條件的行數(shù)。開發(fā)中常用來統(tǒng)計(jì)表中數(shù)據(jù),全部數(shù)據(jù),不為NULL數(shù)據(jù),或者去重?cái)?shù)據(jù)。
2. COUNT()參數(shù)說明
COUNT(1):統(tǒng)計(jì)不為NULL 的記錄。
COUNT(*):統(tǒng)計(jì)所有的記錄(包括NULL)。
COUNT(字段):統(tǒng)計(jì)該"字段"不為NULL 的記錄。
1.如果這個(gè)字段是定義為not null的話,一行行地從記錄里面讀出這個(gè)字段,判斷不能為null,按行累加。
2.如果這個(gè)字段定義允許為null的話,判斷到有可能是null,還要把值取出來在判斷一下,不是null才累加。
COUNT(DISTINCT 字段):統(tǒng)計(jì)該"字段"去重且不為NULL 的記錄。
-- MySql統(tǒng)計(jì)函數(shù)count測(cè)試 -- 創(chuàng)建用戶表,新增測(cè)試數(shù)據(jù) CREATE TABLE `user` ( `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID主鍵', `name` varchar(64) DEFAULT NULL COMMENT '姓名', `sex` varchar(8) DEFAULT NULL COMMENT '性別', `age` int(4) DEFAULT NULL COMMENT '年齡', `born` date DEFAULT NULL COMMENT '出生日期', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC COMMENT='用戶表'; INSERT INTO `category`.`user`(`id`, `name`, `sex`, `age`, `born`) VALUES (1, '%張三%', '男', 22, '2022-04-22'); INSERT INTO `category`.`user`(`id`, `name`, `sex`, `age`, `born`) VALUES (2, '李四', '女', 12, '2022-04-01'); INSERT INTO `category`.`user`(`id`, `name`, `sex`, `age`, `born`) VALUES (3, '王小二', '女', 12, '2022-04-28'); INSERT INTO `category`.`user`(`id`, `name`, `sex`, `age`, `born`) VALUES (4, '趙四', '男', 23, '2022-04-28'); INSERT INTO `category`.`user`(`id`, `name`, `sex`, `age`, `born`) VALUES (5, '', '女', 23, '2022-04-28'); INSERT INTO `category`.`user`(`id`, `name`, `sex`, `age`, `born`) VALUES (6, NULL, '女', 60, '2022-04-28'); INSERT INTO `category`.`user`(`id`, `name`, `sex`, `age`, `born`) VALUES (7, NULL, '女', 61, '2022-04-28'); select * from user; -- 統(tǒng)計(jì)數(shù)據(jù):7條數(shù)據(jù),統(tǒng)計(jì)所有的記錄(包括NULL)。 select count(*) from user; -- 統(tǒng)計(jì)數(shù)據(jù):7條數(shù)據(jù),統(tǒng)計(jì)不為NULL 的記錄。 select count(1) from user; -- 統(tǒng)計(jì)數(shù)據(jù):5條數(shù)據(jù),COUNT(字段):統(tǒng)計(jì)該"字段"不為NULL 的記錄,注意是null不是空''字符串 select count(name) from user; -- 統(tǒng)計(jì)數(shù)據(jù):5條數(shù)據(jù),COUNT(DISTINCT 字段):統(tǒng)計(jì)該"字段"去重且不為NULL 的記錄。 select count(distinct name) from user;
3. COUNT()判斷存在
SQL不再使用count,而是改用LIMIT 1,讓數(shù)據(jù)庫(kù)查詢時(shí)遇到一條就返回,不要再繼續(xù)查找還有多少條了,業(yè)務(wù)代碼中直接判斷是否非空即可。
select 1 from emp LIMIT 1;效率是最高的,尤其是需要limit限制行數(shù),很容易忽略。
-- SQL查找是否"存在" -- 員工表,存在則進(jìn)行刪除 drop table if EXISTS emp; create table emp( id int unsigned primary key auto_increment, empno mediumint unsigned not null default 0, empname varchar(20) not null default "", job varchar(9) not null default "", mgr mediumint unsigned not null default 0, hiredate datetime not null, sal decimal(7,2) not null, comn decimal(7,2) not null, depno mediumint unsigned not null default 0 ); -- 新增cehsi數(shù)據(jù) 測(cè)試數(shù)據(jù):https://blog.csdn.net/m0_37583655/article/details/124385347 -- cahxun select * from emp ; -- 時(shí)間:1.082s,數(shù)據(jù):5000000 explain select count(*) from emp; id select_type table partitions type possible_keys key key_len ref rows filtered Extra 1 SIMPLE Select tables optimized away -- 時(shí)間:1.129s,數(shù)據(jù):5000000 explain select count(1) from emp; id select_type table partitions type possible_keys key key_len ref rows filtered Extra 1 SIMPLE Select tables optimized away -- 時(shí)間:1.695s,數(shù)據(jù):5000000 explain select 1 from emp; id select_type table partitions type possible_keys key key_len ref rows filtered Extra 1 SIMPLE emp idx_emp_depno 3 4981060 100.00 Using index -- SQL不再使用count,而是改用LIMIT 1,讓數(shù)據(jù)庫(kù)查詢時(shí)遇到一條就返回,不要再繼續(xù)查找還有多少條了,業(yè)務(wù)代碼中直接判斷是否非空即可 -- 時(shí)間:0.001s,數(shù)據(jù):5000000 explain select 1 from emp LIMIT 1; id select_type table partitions type possible_keys key key_len ref rows filtered Extra 1 SIMPLE emp idx_emp_depno 3 4981060 100.00 Using index
4. COUNT()阿里開發(fā)規(guī)范
1.【強(qiáng)制】不要使用 count(列名)或 count(常量)來替代 count(),count()是 SQL92 定義的標(biāo) 準(zhǔn)統(tǒng)計(jì)行數(shù)的語法,跟數(shù)據(jù)庫(kù)無關(guān),跟 NULL 和非 NULL 無關(guān). 說明:count(*)會(huì)統(tǒng)計(jì)值為 NULL 的行,而 count(列名)不會(huì)統(tǒng)計(jì)此列為 NULL 值的行.
2.【強(qiáng)制】count(distinct col) 計(jì)算該列除 NULL 之外的不重復(fù)行數(shù),注意 count(distinct col1, col2) 如果其中一列全為 NULL,那么即使另一列有不同的值,也返回為 0.
到此這篇關(guān)于MySql統(tǒng)計(jì)函數(shù)COUNT的具體使用詳解的文章就介紹到這了,更多相關(guān)MySql統(tǒng)計(jì)函數(shù)COUNT內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL使用正則表達(dá)式進(jìn)行查詢操作經(jīng)典實(shí)例總結(jié)
這篇文章主要介紹了MySQL使用正則表達(dá)式進(jìn)行查詢操作,結(jié)合實(shí)例形式總結(jié)分析了各種常見匹配模式的查詢操作實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2018-06-06win8.1安裝mysql5.6時(shí)遇到問題解決方案
本文主要記錄的是作者在win8.1安裝mysql5.6時(shí)遇到問題的解決方案,網(wǎng)上查了很多方法都沒能解決,這里把最后的方法分享給大家2016-10-10MySQL數(shù)據(jù)庫(kù)分組查詢group by語句詳解
這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)分組查詢group by語句詳解,文中含有詳細(xì)示例代碼說明解析,有需要的朋友可以借鑒參考想=下,希望能夠有所幫助2021-09-09mysql InnoDB建表時(shí)設(shè)定初始大小的方法
這篇文章主要介紹了mysql InnoDB建表時(shí)設(shè)定初始大小的方法,需要大家到MYSQL后臺(tái)實(shí)際操作方可以看到效果2013-11-11mysql跨數(shù)據(jù)庫(kù)復(fù)制表(在同一IP地址中)示例
這篇文章主要介紹了mysql跨數(shù)據(jù)庫(kù)復(fù)制表(在同一IP地址中)示例,需要的朋友可以參考下2014-03-03mysql如何修改表結(jié)構(gòu)(alter table),多列/多字段
這篇文章主要介紹了mysql如何修改表結(jié)構(gòu)(alter table),多列/多字段問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12MySql利用父id遞歸向下查詢子節(jié)點(diǎn)的方法實(shí)例
項(xiàng)目中遇到一個(gè)需求,要求查處菜單節(jié)點(diǎn)的所有節(jié)點(diǎn),在網(wǎng)上查了一下,大多數(shù)的方法用到了存儲(chǔ)過程,由于線上環(huán)境不能隨便添加存儲(chǔ)過程,所以自己寫一個(gè),這篇文章主要給大家介紹了關(guān)于MySql利用父id遞歸向下查詢子節(jié)點(diǎn)的相關(guān)資料,需要的朋友可以參考下2022-03-03MYSQL 一個(gè)巧用字符函數(shù)做數(shù)據(jù)篩選的題
這篇文章主要介紹了MYSQL 一個(gè)巧用字符函數(shù)做數(shù)據(jù)篩選的題,需要的朋友可以參考下2017-05-05