我想在现有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)。此列也是主键。
这不是一个重复的问题,因为我找到的其他答案的解决方案无法解决我的问题。
答案 0 :(得分:3)
您使用的语法错误,请尝试以下命令 -
ALTER TABLE `myTable` CHANGE `myCol1` `myCol1` INT(11) NOT NULL AUTO_INCREMENT, auto_increment=2500;