jerome66 2017-05-26 12:49 采纳率: 46.7%
浏览 3944
已采纳

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
    关注

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

    评论
查看更多回答(7条)

报告相同问题?

悬赏问题

  • ¥100 webapi的部署(标签-服务器)
  • ¥20 怎么加快手机软件内部计时的时间(关键词-日期时间)
  • ¥15 C语言除0问题的检测方法
  • ¥15 为什么四分管的内径有的是16mm有的15mm,四分不应该是12.7mm吗
  • ¥15 macos13下 ios交叉编译的问题
  • ¥15 bgz压缩文件怎么打开
  • ¥15 封装dll(引入了pcl的点云设计库)
  • ¥30 关于#开发语言#的问题:我需要在抄板的基础上再抄板抄程序,根据RDA8851CM基础上开发
  • ¥15 oracle 多个括号,怎么删除指定的括号及里面的内容?
  • ¥15 小新14API2019想用bios调风扇