jerome66
jerome66
采纳率46.7%
2017-05-26 12:49

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

10
已采纳

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

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

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

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

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

8条回答

  • dboy_zhu dboy_zhu 4年前

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

    点赞 1 评论 复制链接分享
  • qq_21521939 盛天海 4年前

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

    点赞 评论 复制链接分享
  • qq_21521939 盛天海 4年前

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

    点赞 评论 复制链接分享
  • gggfkhk gggfkhk 4年前

    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

    点赞 评论 复制链接分享
  • crpxnmmafq changzhiqiang_ 4年前

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

    点赞 评论 复制链接分享
  • qq_21521939 盛天海 4年前

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

    点赞 评论 复制链接分享
  • qq_21521939 盛天海 4年前

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

    点赞 评论 复制链接分享
  • qq_42461905 qq_42461905 6月前

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

    点赞 评论 复制链接分享

相关推荐