gpt4 book ai didi

php - 删除行后重置数字序列

转载 作者:行者123 更新时间:2023-11-29 21:23:18 24 4
gpt4 key购买 nike

如果我有一个包含以下数据的用户列表:

+----+---------+----------+
| id | user | sequence |
+----+---------+----------+
| 2 | dave | 1 |
| 3 | sam | 2 |
| 4 | harry | 3 |
| 5 | sarah | 4 |
+----+---------+----------+

如果我删除用户 harry,我想重新排序序列列以提供以下内容:

+----+---------+----------+
| id | user | sequence |
+----+---------+----------+
| 2 | dave | 1 |
| 3 | sam | 2 |
| 5 | sarah | 3 |
+----+---------+----------+

我尝试过以下方法:

SET @i = 0;
UPDATE users
SET `sequence` = @i:=@i+1
ORDER BY `sequence` ASC;

如果我使用 MySQL Workbench 运行它,它就可以工作。但是,当通过 PHP 方法运行时 mysql_query它失败并出现错误:您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,了解使用近的正确语法

如果我单独运行这些语句,它就会起作用。这是一种安全的方法吗?是否会出现问题?是否有解决方法或更好的方法来编写该声明?

该应用程序未使用 mysqli,因此我无法使用 http://php.net/manual/en/mysqli.multi-query.php

最佳答案

它失败了,因为您尝试了多重查询。你也许可以使用 http://php.net/manual/en/mysqli.quickstart.multiple-statement.php或尝试将其分开。在这种情况下,我会将其放入交易中,那么它应该是安全的。 http://php.net/manual/en/mysqli.begin-transaction.php

关于php - 删除行后重置数字序列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35624020/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com