数据库常用语法--count/gourp by/having/order by

本文介绍了数据库中的四个关键语法:count用于统计记录数,包括count(*)统计全部记录和count(列名)统计非空记录;group by用于数据分组,常与count配合;having用于过滤分组后的结果;order by则根据指定条件对数据进行排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

count

作用:统计记录数。
(1)count(*)—包括所有列,返回表中的记录数,相当于统计表的行数,在统计结果的时候,包含NULL的记录,且不去重。
(2)count(列名)—只包括列名指定列,返回指定列的非空的记录数,在统计结果的时候,不包含为NULL的记录。
(3)count(distinct 列名)—只包括列名指定列,返回指定列的不同值的记录数,即会去重,且不包含列值为NULL的记录。

SELECT count(*) FROM student //查询总记录条数
SELECT count(name) FROM student //查询name列非空的记录条数
SELECT count(distinct name) FROM student //查询name列非空的去重后的记录条数

举例:
student表有5条初始记录,其中第五条name为null。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

group by

作用:分组函数,一般与count联合使用。

SELECT  name,count(*) FROM student GROUP BY name //统计相同name值的记录数,返回列表(包含NULL值)。

在这里插入图片描述

having

having语句通常与group by语句联合使用,用来过滤由group by语句返回的记录集。having语句的存在弥补了where关键字不能与聚合函数联合使用的不足。

SELECT  name,count(*) FROM student GROUP BY name HAVING name='lisi';

在这里插入图片描述

order by

作用:根据指定条件进行排序

SELECT  name,count(*) FROM student GROUP BY name order by name asc; //根据name顺序排列

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值