Non è possibile utilizzare order by e limit nella dichiarazione di aggiornamento nel caso di più tabelle.
Citando dalla documentazione MySQL:
UPDATE user u
INNER JOIN
(
SELECT
*,
(@i := (@i + 1)) AS row_number
FROM user u
CROSS JOIN (SELECT @i := 0) r
WHERE user_active=1
ORDER BY user_planets DESC
)AS t
ON u.Primary_key = t.primary_key
SET u.user_rank_planets = t.row_number.
Nota: Sostituisci u.Primary_key
e t.primary_key
dalla chiave primaria di user
tabella.
Leggi i primi paragrafi http://dev.mysql.com/doc /refman/5.7/en/update.html