MySQL重置 Auto_increment字段起始值

有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. 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



来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29096438/viewspace-1823326/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29096438/viewspace-1823326/

你可能感兴趣的:(MySQL重置 Auto_increment字段起始值)