如果自增长的id值超过了字段表示范围会怎么样?
我有一个表,每天会插入上千万条数据,但是只保留几天内的,旧数据会清除。但是这样的话,id仍然是一直增长的,我的id设置为int,理论上能表示42亿的数字,但按照这样的速度,很会很快用完的,如果id值增长到int表示范围的上限,会发生什么呢? 可以在 tinyint 列上做个测验
回复 1# number321
回复 2# asdf2110
将 IDENTITY 转换为数据类型 tinyint 时出现算术溢出错误。
发生算术溢出。
报这个错,看来就算定期删除,当标号到达上限时也会导致问题的。不知道那些每天有上千万或者上亿的数据插入的数据库,id字段是设置成什么类型的呢,是bigint吗,这样会不会浪费存储空间? 我理解的是,既然是 auto_increment,那么应用是不会主给该字段插入值的,比如t(a int auto_increment, b int);
那么应用应该是insert into t(b) values(111);
对你的系统,id 是唯一索引吗? 如果是,用光了应该会报错,如果不是,那么 后面的id可能会重复的都是一个值,就像 tinyint 都是 127 一样
回复 3# number321
回复 4# asdf2110
是唯一索引,如果是这样的话,那么是不是很大的数据库一般都用bigint来作为自增长的ID字段,还是用其他方法来避免这种增长到上限的问题呢? 这类问题还没接触过,可以找机会测试一下 恩,把这种字段设置成 bigint 或 numeric 等
如果你搜“auto_increment 重置”,会提供到两种方法,一种是 truncate table,还有一种 recreate
不过这两种都需要重新导入数据,代价会比较大
回复 5# number321
页:
[1]