gpt4 book ai didi

mysql - 在不影响当前记录值的情况下向现有列添加自动增量

转载 作者:行者123 更新时间:2023-11-30 21:56:25 25 4
gpt4 key购买 nike

我想在现有的 MyISAM1 数据库表中将列类型更改为 AUTO_INCREMENT。该数据库目前有数千条记录,其中列值非常重要。当前值不受影响是至关重要的。我想从最新的最高值开始递增。

我在 phpmyadmin 中试过这个(由 phpmyadmin 生成的 sql)并得到了一个错误。

ALTER TABLE `myTable` CHANGE `myCol1` `myCol1` INT(11) NOT NULL AUTO_INCREMENT;

我得到的错误是:

 ALTER TABLE causes auto_increment resequencing, resulting in duplicate entry '2197' for key 'PRIMARY'

我做了一些研究,发现通过添加偏移量应该可以解决我的问题。我试过了,但遇到了语法错误。

ALTER TABLE `myTable` CHANGE `myCol1` INT(11) NOT NULL AUTO_INCREMENT = 2500

错误:

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'INT(11) NOT NULL AUTO_INCREMENT = 2500' at line 1 

上面的sql我也试过没有声明INT

简单地说,我需要保持现有记录的原样,但向 myCol1 列添加自动递增功能,从数字 2500 开始(目前最后一项是 2498)。此列也是主键。

这不是一个重复的问题,因为我为其他答案找到的解决方案并没有解决我的问题。

最佳答案

您使用了错误的语法,请尝试以下命令-

ALTER TABLE `myTable` CHANGE `myCol1` `myCol1` INT(11) NOT NULL AUTO_INCREMENT, auto_increment=2500;

关于mysql - 在不影响当前记录值的情况下向现有列添加自动增量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45017101/

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