Mysql
 sql >> Datenbank >  >> RDS >> Mysql

mysql aktualisiert eine Spalte mit einem int basierend auf der Reihenfolge

SET @rownumber = 0;    
update mytable set Moneyorder = (@rownumber:[email protected]+1)
order by MoneyOrder asc

oder um es in einer einzigen Abfrage zu tun, können Sie es versuchen

update mytable target
join
(
     select id, (@rownumber := @rownumber + 1) as rownum
     from mytable         
     cross join (select @rownumber := 0) r
     order by MoneyOrder asc
) source on target.id = source.id    
set Moneyorder = rownum