MySQL中的分段组

发布于 2024-12-29 12:30:55 字数 368 浏览 0 评论 0原文

如何将 MySQL 表中的连续数据分组并将其数量存储到额外的列中?

例如:

id, n

1   10
2   10
3   10
4   56
5   10
6   10
7   80
8   12

我想要得到这样的东西。请注意,n of 10 被列出了两次。

id   n   cnt
 1   10   3
 4   56   1
 5   10   2
 7   80   1
 8   12   1

有没有办法在没有 FUNCTION 的情况下做到这一点?

How I can to group continuous data in MySQL table and store its number to an extra column?

For example:

id, n

1   10
2   10
3   10
4   56
5   10
6   10
7   80
8   12

I want to get something like this. Notice that n of 10 is listed twice.

id   n   cnt
 1   10   3
 4   56   1
 5   10   2
 7   80   1
 8   12   1

Is that any way to do this without FUNCTION?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

明媚如初 2025-01-05 12:30:55

您可以使用 MySQL 变量

select
      min( PreQuery.ID ) as StartIDOfGroup,
      PreQuery.n,
      count(*) as Cnt
   from
      ( select yt.id,
               yt.n,
               @CommonGroup := @CommonGroup + if( @LastNValue = yt.n, 0, 1 ) as Common,
               @LastNValue := yt.n as JustAPlaceholder
           from
              YourTable yt,
              ( select @CommonGroup := 0, @LastNValue := 0 ) SQLVars ) PreQuery
   group by
      PreQuery.n,
      PreQuery.Common
   order by
      StartIDOfGroup

You can with use of MySQL Variables

select
      min( PreQuery.ID ) as StartIDOfGroup,
      PreQuery.n,
      count(*) as Cnt
   from
      ( select yt.id,
               yt.n,
               @CommonGroup := @CommonGroup + if( @LastNValue = yt.n, 0, 1 ) as Common,
               @LastNValue := yt.n as JustAPlaceholder
           from
              YourTable yt,
              ( select @CommonGroup := 0, @LastNValue := 0 ) SQLVars ) PreQuery
   group by
      PreQuery.n,
      PreQuery.Common
   order by
      StartIDOfGroup
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文