我想将列类型更改为AUTO_INCREMENT
在现有的MyISAM1
数据库表。数据库目前有数千条记录,其中列值非常重要。当前值不受影响至关重要。我想从最新的最高值开始递增。
我在 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
error:
#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;
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)