error java.sql.SQLException:Failed to read auto-increment value from storage

error java.sql.SQLException:Failed to read auto-increment value from storage,报错原因为数据表中的自增字段读取错误

解决办法一:

1、先查看自增字段的长度以及当前最大值,看是否已经到达最大值,如果是,可以增加字段长度

2、若不是,可先查看当前数据表自增字段当前值,

SELECT auto_increment FROM information_schema.tables where table_schema="数据库名称" and table_name="表名称";

若值已经超过字段长度的最大值,查看当前表中自增字段的最大值 a ,然后重新设置自增的初始值,初始值为 b = a+1,命令为:

alter table 表名 AUTO_INCREMENT=b;

 

解决办法二:

该方法并未实际测试,为网上办法,感兴趣的可以试下:

1、把涉及数据表的自增字段的自增选项去掉,保存一下

2、重新将这个字段设置为自增字段

 

知识延申:

查看当前数据表自增字段当前值

SELECT auto_increment FROM information_schema.tables where table_schema="数据库名称" and table_name="表名称";

注:每张表里只可以有一个自增字段,auto_increment返回的是下一条插入记录的id值,而不是当前的最大id值

 

你可能感兴趣的:(mysql,mysql)