Не можете да използвате order by и limit в изявлението за актуализиране в случай на множество таблици.
Цитат от MySQL Documentation:
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.
Забележка: Заменете u.Primary_key
и t.primary_key
от първичния ключ на user
таблица.
Прочетете първите няколко абзаца http://dev.mysql.com/doc /refman/5.7/bg/update.html