jerome66
2017-05-26 12:49
采纳率: 46.7%
浏览 3.9k

sql去重后统计数据大小的问题

我想要对如下的表按照file-name字段去重后,再统计file-size的和。
data_source表

我查到了去重常用的distinct方法,但是只能去重,不能进行统计,如下图。
distinct去重

然后我又查到查重统计的方法,通过group by 和having,但是也不太符合我的要求,如下图所示。
groupby
另外,不能删除库内的数据,所以也不能删掉重复数据后查询。

根据图一中的数据,我如果进行统计file-size的话,应该是7k,而不是15k。
统计大小
请问,对于去重统计的需求,应该用什么方法呢?

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

8条回答 默认 最新

  • dboy_zhu 2017-05-27 00:16
    已采纳

    select sum(tt.file_size) from (select distinct(file_name),file_size from data_source) tt

    打赏 评论
  • 盛天海 2017-05-26 13:08

    select file_name ,sum(file_size) from testRepeat.data_source group by file_name

    打赏 评论
  • 盛天海 2017-05-26 13:15

    count是用来计数的 算一共有几行 查到的是对的 方法不对

    打赏 评论
  • changzhiqiang_ 2017-05-26 13:43

    把distinct查询file-name的结果集作为查询条件嵌套查询

    打赏 评论
  • gggfkhk 2017-05-26 13:55

    mysql语法可以这么写:CREATE TEMPORARY TABLE tmp_bc SELECT distinct(file_name),file_size FROM data_source;select sum(file_size) from tmp_bc
    mssql:select distinct(file_name),file_size into #tmp_bc from data_source; select sum(file_size) from tmp_bc

    打赏 评论
  • 盛天海 2017-05-27 07:26

    ![图片说明](https://img-ask.csdn.net/upload/201705/27/1495869676_306820.png)<br>
图片说明

    打赏 评论
  • 盛天海 2017-05-27 07:27

    不知道你的是则么写的 我的回答是没有问题的

    打赏 评论
  • qq_42461905 2020-10-19 11:10

    这个就是利用子查询,把第一次查询出来的表当做一个伪表再进行统计一次就可以了

    打赏 评论

相关推荐 更多相似问题