複数のテーブルの場合、updateステートメントでorderbyとlimitを使用することはできません。
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.
注: u.Primary_key
を置き換えます およびt.primary_key
user
の主キーによる テーブル。
最初の数段落を読む