如何对表中列中的日期进行排序?(时间戳)请注意,我不是要求按日期对行进行排序,而是在询问如何在记录中交换日期,以便所有日期都按正确的顺序排列;无需更改任何其他内容。所以;例如:id foo bar1 A 03-03-20302 B 01-01-20103 C 02-02-2020成为。。。id foo bar1 A 01-01-20102 B 02-02-20203 C 03-03-2030首选解决方案使用直接 MySQL 或 MySQL 和 PHP。
1 回答
Cats萌萌
TA贡献1805条经验 获得超9个赞
您可以使用CTE使用MySQL查询更新表,该CTE计算每行的,排序方式为 和 ;将每个值替换为具有相应按行号排序的值:ROW_NUMBER()idbarbaridbar
WITH CTE AS (
SELECT id, bar,
ROW_NUMBER() OVER (ORDER BY id) AS rn_id,
ROW_NUMBER() OVER (ORDER BY bar) AS rn_bar
FROM data
)
UPDATE data d
JOIN CTE c1 ON c1.id = d.id
JOIN CTE c2 ON c2.rn_bar = c1.rn_id
SET d.bar = c2.bar
输出(对于您的示例数据):
id foo bar
1 A 2010-01-01
2 B 2020-02-02
3 C 2030-03-03
- 1 回答
- 0 关注
- 107 浏览
添加回答
举报
0/150
提交
取消