如何重置字段的AUTO_INCREMENT?
我希望它再次从1开始计数。
如何重置字段的AUTO_INCREMENT?
我希望它再次从1开始计数。
当前回答
表格的自动递增计数器可以通过两种方式设置:
通过执行查询,就像其他人已经解释过的那样:ALTER TABLE<TABLE_name>AUTO_INCREMENT=<TABLE_id>;使用Workbench或其他可视化数据库设计工具。我将在Workbench中展示它是如何实现的,但在其他工具中也应该不会有太大不同。右键单击所需的表格,然后从上下文菜单中选择Alter table。在底部,您可以看到更改表格的所有可用选项。选择“选项”,您将获得此表单:
然后,只需在自动增量字段中设置所需的值,如图所示。这将基本上执行第一个选项中显示的查询。
其他回答
SET @num := 0;
UPDATE your_table SET id = @num := (@num+1);
ALTER TABLE your_table AUTO_INCREMENT =1;
就像这样:
ALTER TABLE tablename AUTO_INCREMENT = value;
参考:13.1.9 ALTER TABLE语句
我搜索了一下,发现了这个问题,但我真正想要的答案满足两个标准:
使用纯MySQL查询将现有表自动增量重置为max(id)+1
由于我在这里找不到我想要的东西,我从各种答案中拼凑出了答案,并在这里分享。
需要注意的几点:
所讨论的表是InnoDB该表使用类型为int的字段id作为主键在MySQL中实现这一点的唯一方法是使用存储过程我下面的图片使用SequelPro作为GUI。您应该能够根据您首选的MySQL编辑器对其进行调整我已经在MySQL Ver 14.14 Distrib 5.5.61上为debian linux gnu测试了这一点
步骤1:创建存储过程
创建如下存储过程:
DELIMITER //
CREATE PROCEDURE reset_autoincrement(IN tablename varchar(200))
BEGIN
SET @get_next_inc = CONCAT('SELECT @next_inc := max(id) + 1 FROM ',tablename,';');
PREPARE stmt FROM @get_next_inc;
EXECUTE stmt;
SELECT @next_inc AS result;
DEALLOCATE PREPARE stmt;
set @alter_statement = concat('ALTER TABLE ', tablename, ' AUTO_INCREMENT = ', @next_inc, ';');
PREPARE stmt FROM @alter_statement;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
END //
DELIMITER ;
然后运行它。
在运行之前,当您查看数据库中的“存储过程”时,情况如下。
运行时,只需选择存储过程并按run Selection
注意:分隔符部分至关重要。因此,如果你复制并粘贴这个问题中最热门的答案,它们往往不会因为这个原因而起作用。
运行后,我应该看到存储过程
如果需要更改存储过程,则需要删除存储过程,然后选择再次运行。
步骤2:调用存储过程
这次您可以简单地使用普通MySQL查询。
call reset_autoincrement('products');
最初来自我自己的SQL查询注释https://simkimsia.com/reset-mysql-autoincrement-to-max-id-plus-1/并适用于堆栈溢出。
我建议您转到查询浏览器并执行以下操作:
转到schemata并找到要更改的表。右键单击并选择复制创建语句。打开一个结果选项卡并粘贴create语句。转到create语句的最后一行,查找Auto_Increment=N,(其中N是自动增量字段的当前编号。)将N替换为1。按Ctrl+Enter键。
在表中输入新行后,Auto_increment应重置为1。
我不知道如果您尝试在auto_increment字段值已经存在的地方添加一行,会发生什么。
您需要遵循Miles M评论中的建议,这里有一些PHP代码可以修复MySQL中的范围。此外,您还需要打开my.ini文件(MySQL),并将max_execution_time=60更改为max_exece_time=6000;对于大型数据库。
不要使用“ALTER TABLE tablename AUTO_INCREMENT=1”。它将删除数据库中的所有内容。
$con = mysqli_connect($dbhost, $dbuser, $dbpass, $database);
$res = mysqli_query($con, "select * FROM data WHERE id LIKE id ORDER BY id ASC");
$count = 0;
while ($row = mysqli_fetch_array($res)){
$count++;
mysqli_query($con, "UPDATE data SET id='".$count."' WHERE id='".$row['id']."'");
}
echo 'Done reseting id';
mysqli_close($con);