[英]Update table based on row number
我有一个带有整数字段的表,用于控制记录的自定义显示顺序。
例:
SET @rownumber = 0;
SELECT
@rownumber:=@rownumber+1 AS rownumber,
slides.displayorder
WHERE
active = 1
ORDER BY displayorder ASC
这个查询给我的结果是这样的:
rownumber | displayorder
-----------+-------------
1 2
2 7
3 15
4 50
5 80
这可以正常进行,直到记录被删除/未经批准(因此显示顺序中的空白)。
我想做的是运行一个更新查询,该查询在删除记录后将displayorder
列设置为rownumber变量的值。
得到这样的结果:
rownumber | displayorder
-----------+-------------
1 1
2 2
3 3
4 4
5 5
是否有捷径可寻?
这似乎可以完成工作。
SET @rownumber = 0;
INSERT INTO slides (id, displayorder)
SELECT a.id, a.rownumber
FROM (SELECT id, (@rownumber:=@rownumber+1) AS rownumber FROM slides WHERE active = 1 ORDER BY displayorder ASC) AS a ON DUPLICATE KEY UPDATE displayorder = a.rownumber
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.