<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
COUNT() 是一個聚合函數,返回指定匹配條件的行數。開發中常用來統計表中資料,全部資料,不為NULL資料,或者去重資料。
COUNT(1):統計不為NULL 的記錄。
COUNT(*):統計所有的記錄(包括NULL)。
COUNT(欄位):統計該"欄位"不為NULL 的記錄。
1.如果這個欄位是定義為not null的話,一行行地從記錄裡面讀出這個欄位,判斷不能為null,按行累加。
2.如果這個欄位定義允許為null的話,判斷到有可能是null,還要把值取出來在判斷一下,不是null才累加。
COUNT(DISTINCT 欄位):統計該"欄位"去重且不為NULL 的記錄。
-- MySql統計函數count測試 -- 建立使用者表,新增測試資料 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; -- 統計資料:7條資料,統計所有的記錄(包括NULL)。 select count(*) from user; -- 統計資料:7條資料,統計不為NULL 的記錄。 select count(1) from user; -- 統計資料:5條資料,COUNT(欄位):統計該"欄位"不為NULL 的記錄,注意是null不是空''字串 select count(name) from user; -- 統計資料:5條資料,COUNT(DISTINCT 欄位):統計該"欄位"去重且不為NULL 的記錄。 select count(distinct name) from user;
SQL不再使用count,而是改用LIMIT 1,讓資料庫查詢時遇到一條就返回,不要再繼續查詢還有多少條了,業務程式碼中直接判斷是否非空即可。
select 1 from emp LIMIT 1;效率是最高的,尤其是需要limit限制行數,很容易忽略。
-- SQL查詢是否"存在" -- 員工表,存在則進行刪除 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資料 測試資料:https://blog.csdn.net/m0_37583655/article/details/124385347 -- cahxun select * from emp ; -- 時間:1.082s,資料: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 -- 時間:1.129s,資料: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 -- 時間:1.695s,資料: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,讓資料庫查詢時遇到一條就返回,不要再繼續查詢還有多少條了,業務程式碼中直接判斷是否非空即可 -- 時間:0.001s,資料: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
1.【強制】不要使用 count(列名)或 count(常數)來替代 count(),count()是 SQL92 定義的標 準統計行數的語法,跟資料庫無關,跟 NULL 和非 NULL 無關. 說明:count(*)會統計值為 NULL 的行,而 count(列名)不會統計此列為 NULL 值的行.
2.【強制】count(distinct col) 計算該列除 NULL 之外的不重複行數,注意 count(distinct col1, col2) 如果其中一列全為 NULL,那麼即使另一列有不同的值,也返回為 0.
到此這篇關於MySql統計函數COUNT的具體使用詳解的文章就介紹到這了,更多相關MySql統計函數COUNT內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45