将自动增量添加到现有列,而不会影响当前记录值

时间:2016-01-04 11:33:04

标签: mysql

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

我在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

简单地说我需要保留现有记录,但是从列号2500开始向列myCol1添加自动增量功能(因为当前最后一项是2498)。此列也是主键。

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

1 个答案:

答案 0 :(得分:3)

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

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