MYSQL - 警告:#1287 在表达式中设置用户变量已被弃用,并将在未来版本中删除

dig*_*web 3 mysql row-number window-functions

警告:#1287 在表达式中设置用户变量已被弃用,并将在未来版本中删除。考虑替代方案:“SET 变量 = 表达式,...”或“SELECT 表达式 INTO 变量”。

这是 MySQL 8.0.21 吐出的内容。该代码可以工作......但我也需要它在未来的版本中工作......所以我的问题是这个警告的正确方法是什么?

我需要将一个变量设置为某个数字(我将通过行的 ID 获得该数字)。我需要在每个 SET 语句中将其加 1。

我应该如何更改此代码以使警告消失?

SET @fromorder = (SELECT `order` FROM forms WHERE id=5);
/* SET @fromorder = 4;  - so this is the same in the example below */
UPDATE forms SET `order` = @fromorder := @fromorder + 1 WHERE `order` > -1 and `order` <= 4 ORDER BY `order` ASC;
SET @fromorder = null;
Run Code Online (Sandbox Code Playgroud)

据我了解,问题的根源在于:

`order` = @fromorder := @fromorder + 1
Run Code Online (Sandbox Code Playgroud)

我想这需要改变吗?

所以由此可知:

+-------+-----------+
|   id  |   order   |
+-------+-----------+
|   1   |   0       |
|   2   |   1       |
|   3   |   2       |
|   4   |   3       |
|   5   |   4       |
+-------+-----------+
Run Code Online (Sandbox Code Playgroud)

我想通过以下查询得到这个(例如):

+-------+-----------+
|   id  |   order   |
+-------+-----------+
|   1   |   5       |
|   2   |   6       |
|   3   |   7       |
|   4   |   8       |
|   5   |   9       |
+-------+-----------+
Run Code Online (Sandbox Code Playgroud)

这是一个简单的 for 循环,增量 += 1;

for*_*pas 6

您的 MySQL 版本支持窗口函数,通过使用ROW_NUMBER()窗口函数您可以避免变量:

UPDATE forms f
CROSS JOIN (SELECT `order` FROM forms WHERE id = 5) c
INNER JOIN (
  SELECT *, ROW_NUMBER() OVER (ORDER BY `order`) rn
  FROM forms
  WHERE `order` > -1 and `order` <= 4 
) t ON t.id = f.id
SET f.`order` = c.`order` + t.rn;
Run Code Online (Sandbox Code Playgroud)

请参阅演示