ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

mysql-GROUP BY将多个值分组为同一组

2019-11-23 10:15:40  阅读:1185  来源: 互联网

标签:mysql group-by


我有一个与此类似的表:

ID      WEEK
1       1
2       1
3       1
4       2
5       2
6       3
7       3
8       3

这是我当前的查询:

SELECT COUNT(*), `week` FROM data GROUP BY `week`

这是一个sqlfiddle http://sqlfiddle.com/#!2/bfdb6/2/0

我需要的是每两周将行分组为同一个COUNT.

所以代替这个:

COUNT(*)    WEEK
3           1
2           2
3           3
3           4

我会得到:

COUNT(*)    WEEK
5           1
5           2
6           3
3           4

每周还有下周添加COUNT.

修改的问题:

我应该明确我真正需要的东西.

而不是将第1周和第3周分组,我需要的是每2周分组一次.

因此,按第1和第2周,第2和第3周,第3和第4周,第4和第5周等分组

如果可能,将自动进行,但是可以在查询之外针对周分组生成sql.

谢谢.

解决方法:

我想我有给你…

首先,从数据中获得不同的可用周…
然后,加入数据,但要特别在第1周或第1周

我将此应用到您现有的SQLFiddle,它似乎可以工作.

select
      JustWeeks.`week`,
      Count(*) as TwoWeekSum
   from
      ( select distinct
              `week`
           from
              data ) JustWeeks
      JOIN data 
         ON JustWeeks.`week` = data.`week`
         OR JustWeeks.`week` +1 = data.`week`
   group by
      JustWeeks.`week`

标签:mysql,group-by
来源: https://codeday.me/bug/20191123/2066946.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有