首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL表的交错行

MySQL表的交错行
EN

Stack Overflow用户
提问于 2014-09-03 15:00:47
回答 2查看 1.2K关注 0票数 2

我有一个包含数据和类的表,类似于

代码语言:javascript
运行
复制
----------------
| DATA | Class |
----------------
|  1   |   A   |
|  2   |   A   |
|  5   |   B   |
|  10  |   A   |
|  2   |   A   |
|  45  |   B   |
|  90  |   B   |
----------------

我想把这两门课混在一起,得到这样的东西:

代码语言:javascript
运行
复制
----------------
| DATA | Class |
----------------
|  1   |   A   |
|  5   |   B   |
|  2   |   A   |
|  45  |   B   |
|  2   |   A   |
|  90  |   B   |
|  10  |   A   |
----------------

我考虑动态生成一个额外的列,该列将为每个单独的类添加一个顺序的递增索引,并对该类进行排序,但需要一个良好的方向/指针。

类似于:

代码语言:javascript
运行
复制
-----------------------
| DATA | Class | indx |
-----------------------
|  1   |   A   |  1   |
|  5   |   B   |  1   |
|  2   |   A   |  2   |
|  45  |   B   |  2   |
|  2   |   A   |  3   |
|  90  |   B   |  3   |
|  10  |   A   |  4   |
-----------------------

甚至可以只使用MySQL吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-09-03 15:19:30

独立枚举每个类,然后按枚举排序:

代码语言:javascript
运行
复制
select data, class, idx
from (select a.*,
             (@seqnum := if(@class = class, @seqnum + 1,
                            if(@class := class, 1, 1)
                           )
             ) as idx
      from atable a cross join
           (select @class := NULL, @seqnum := 0) vars
      order by class, data
     ) a
order by idx, class;

编辑:

此查询独立枚举每个类,因此具有最小数据的行的值为1,依此类推。为此,它使用MySQL变量。在其他数据库中,您可以使用row_number()。一旦有了枚举,最后一步就是按该字段进行排序。

票数 4
EN

Stack Overflow用户

发布于 2014-09-03 15:09:09

下面是我可以建议的SQL:

代码语言:javascript
运行
复制
SET @rank:=0;
update aabb set `index` = @rank:=@rank+2 where `class` = 'A';
SET @rank:=1;
update aabb set `index` = @rank:=@rank+2 where `class` = 'B';
select * from aabb order by `index`;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25647685

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档