gpt4 book ai didi

mysql - 如何使用 SQL (MySQL) 对表中的列进行排序?

转载 作者:行者123 更新时间:2023-11-29 07:06:27 24 4
gpt4 key购买 nike

我有一个使用 Hibernate 和索引列映射的列表。该表如下所示:

mysql> select * from chart;
+----+--------+------+-----------------------+
| id | report | indx | name |
+----+--------+------+-----------------------+
| 2 | 1 | 0 | Volume |
| 3 | 2 | 0 | South Africa (Volume) |
| 5 | 2 | 2 | People |
| 6 | 2 | 3 | Platforms |
| 7 | 2 | 4 | People (Gender) |
+----+--------+------+-----------------------+

如您所见,report=2 且 indx=1 的图表 id=4 已被删除。

我需要消除间隙,以便给定报告的所有索引值从 0 开始按顺序运行。我可以编写 Java 代码来解决这个问题,但 SQL 解决方案更容易部署。

有人知道怎么做吗?我正在使用 MySQL。

最佳答案

如果this该技术适用于您可以尝试的 MYSQL 版本

 SET @row := -1;
UPDATE chart
SET indx = @row := @row + 1
WHERE report = 2
ORDER BY indx

但我认为改变设计更好。

关于mysql - 如何使用 SQL (MySQL) 对表中的列进行排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7024643/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com