首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
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

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
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25647685

复制
相关文章

相似问题

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