MySQL重置 Auto_increment字段起始值

本文介绍了MySQL中管理自增ID的两种方法:通过ALTER TABLE调整起始值和使用TRUNCATE清空表来重置自增ID。并讨论了InnoDB和MyISAM存储引擎在重启前后自增ID的行为差异。
有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/

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值