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

Mysql 在不影响当前记录值的情况下向现有列添加自动增量,mysql,Mysql,我想在现有的MyISAM1数据库表中将列类型更改为AUTO_INCREMENT。数据库目前有数千条记录,其中列值非常重要。当前值不受影响至关重要。我想从最新的最高值开始递增 我在phpmyadmin(由phpmyadmin生成的sql)中尝试了这个方法,但得到了一个错误 ALTER TABLE `myTable` CHANGE `myCol1` `myCol1` INT(11) NOT NULL AUTO_INCREMENT; 我得到的错误是: ALTER TABLE causes auto

我想在现有的
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

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


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

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

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