sql查询去重统计的方法总结

说到sql查询去重大家应该都首先会想到distinct 这个关键字。但有时候distinct并不适合某些特殊场景。

场景举例:

下图是我的文件存储表。现在有个需求就是统计上传文件的用户数是多少。

 

如果用distinct 去查询的话数量如下图。数量是8显然不对,正确的数量应该是4,重复的user_id不应该给我统计进去。

distinct 无法满足这种情况怎么办呢,还有一个常用的办法就是利用group by 进行分组统计。请直接看代码我是这么写的SELECT  COUNT(1) AS countUser FROM (SELECT COUNT(1)  FROM sys_file_info GROUP BY user_id ) AS a。这句话查询出来的就是正确的。

分组统计的思路,咱们先看下分组统计是什么样的。根据user_id分了4组,每个分组的数量是1,2,1,4。那么分组数就是去重后的用户数,即4组=4个用户。

咱们这时候统计一下分组的数量就可以了,怎么才能把分组的数量进行统计出来呢。很简单就是利用子查询,把分组查询出来的表当做一个伪表再进行统计一次就可以了。

SELECT  COUNT(1) AS countUser FROM (SELECT COUNT(1)  FROM sys_file_info GROUP BY user_id ) AS a 红色部分是形成一个伪表。蓝色部分是对伪表进行条数统计,那么就得到了分组的数量,即用户数。

  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 可以使用SELECT COUNT(DISTINCT column_name) FROM table_name;语句来对MySQL去重后的数量进行统计。其中,column_name是要去重的列名,table_name是要查询的表名。 ### 回答2: 要使用MySQL去重统计数量,可以使用DISTINCT关键字来去除重复的行,并且结合COUNT函数进行数量统计。 例如,假设有一个名为"employees"的表,其中包含了员工的姓名。我们想要统计不重复的员工数量,可以使用以下的SQL查询语句: SELECT COUNT(DISTINCT name) FROM employees; 这个查询语句会返回一个结果,表示不重复的员工姓名的数量。 另外,如果我们想要统计不同部门的员工数量,可以使用GROUP BY子句来分组统计。例如: SELECT department, COUNT(DISTINCT name) FROM employees GROUP BY department; 这个查询语句会返回一个结果集,其中包含了每个部门的不重复员工数量。 需要注意的是,COUNT函数会统计所有非空值。如果有某个列包含了NULL值,可以使用IS NOT NULL语句来过滤掉这些值。例如: SELECT COUNT(DISTINCT name) FROM employees WHERE name IS NOT NULL; 这个查询语句会排除掉包含NULL值的姓名,并统计剩余部分的数量。 总结起来,要使用MySQL进行去重后的数量统计,可以使用DISTINCT关键字配合COUNT函数来处理。同时,根据需要可以使用GROUP BY子句和其他的条件语句来进一步筛选和分组统计数据。 ### 回答3: 在MySQL中,可以使用DISTINCT关键字来实现去重操作,然后使用聚合函数COUNT()来统计数量。 首先,我们需要使用SELECT语句来选择需要进行去重统计数量的列。假设我们有一个名为"table"的表,其中有一个名为"column"的列,我们想要对该列进行去重操作并统计数量,可以使用以下语句: SELECT COUNT(DISTINCT column) FROM table; 这条语句会返回"column"列中去重后的数量。 举个例子,假设我们有一个名为"students"的表,其中有一个名为"student_name"的列,我们想要对"student_name"列进行去重操作并统计数量,可以使用以下语句: SELECT COUNT(DISTINCT student_name) FROM students; 以上语句会返回"students"表中"student_name"列去重后的数量。 需要注意的是,在使用DISTINCT关键字进行去重操作时,会消耗一定的时间和资源,特别是对于大量数据的表格来说。因此,在实际使用中要谨慎使用,尽量选择合适的索引、优化查询语句等方法来提高性能。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值