繁体   English   中英

根据行号更新表

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM