有2种方法:
1.alter table tbname auto_increment = x ;
设置表tbname的唯一auto_increment字段起始值从x开始,如果此表数据量很多的话,这样执行起来会很慢。
2.truncate tbname ;
直接清空所有数据,下次插入数据时auto_increment字段会自动从0开始。 和delete from tbname不同的是delete只删除数据而不重置auto_incremnet.
下一个自增id是多少
mysql> select AUTO_INCREMENT from INFORMATION_SCHEMA.TABLES where TABLE_NAME='t';
自增idFAQ
1.alter table tbname auto_increment = x ;
设置表tbname的唯一auto_increment字段起始值从x开始,如果此表数据量很多的话,这样执行起来会很慢。
2.truncate tbname ;
直接清空所有数据,下次插入数据时auto_increment字段会自动从0开始。 和delete from tbname不同的是delete只删除数据而不重置auto_incremnet.
下一个自增id是多少
mysql> select AUTO_INCREMENT from INFORMATION_SCHEMA.TABLES where TABLE_NAME='t';
自增idFAQ
- 1.一个t表有a,b字段,a是主键,自增长值.向表中插入10条记录,然后删除5条,再退出终端重启数据库.问:我再插入5条数据是从6开始还是从11开始?
因为innodb重启会回收脏数据,重启后会回收删除后自增长的值,所以innodb是从6开始重新记录,不重启则是11。myisam是数据和索引分开存放的,重启后不会回收数据,会记录自增长的信息,所以会是11 ,
可以理解为未重启:next_id=出现过的max(id)+1
重启:next_id=max(id)+1
可以理解为未重启:next_id=出现过的max(id)+1
重启:next_id=max(id)+1
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29096438/viewspace-1823326/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29096438/viewspace-1823326/
本文介绍了MySQL中管理自增ID的两种方法:通过ALTER TABLE调整起始值和使用TRUNCATE清空表来重置自增ID。并讨论了InnoDB和MyISAM存储引擎在重启前后自增ID的行为差异。
2564

被折叠的 条评论
为什么被折叠?



