number321 发表于 2015-03-18 20:11

如果自增长的id值超过了字段表示范围会怎么样?

我有一个表,每天会插入上千万条数据,但是只保留几天内的,旧数据会清除。
但是这样的话,id仍然是一直增长的,我的id设置为int,理论上能表示42亿的数字,但按照这样的速度,很会很快用完的,如果id值增长到int表示范围的上限,会发生什么呢?

asdf2110 发表于 2015-03-19 14:10

可以在 tinyint 列上做个测验


回复 1# number321


   

number321 发表于 2015-03-19 15:39

回复 2# asdf2110


    将 IDENTITY 转换为数据类型 tinyint 时出现算术溢出错误。
发生算术溢出。

报这个错,看来就算定期删除,当标号到达上限时也会导致问题的。不知道那些每天有上千万或者上亿的数据插入的数据库,id字段是设置成什么类型的呢,是bigint吗,这样会不会浪费存储空间?

asdf2110 发表于 2015-03-19 16:59

我理解的是,既然是 auto_increment,那么应用是不会主给该字段插入值的,比如t(a int auto_increment, b int);
那么应用应该是insert into t(b) values(111);

对你的系统,id 是唯一索引吗? 如果是,用光了应该会报错,如果不是,那么 后面的id可能会重复的都是一个值,就像 tinyint 都是 127 一样


回复 3# number321


   

number321 发表于 2015-03-19 19:24

回复 4# asdf2110


是唯一索引,如果是这样的话,那么是不是很大的数据库一般都用bigint来作为自增长的ID字段,还是用其他方法来避免这种增长到上限的问题呢?

action08 发表于 2015-03-19 20:05

这类问题还没接触过,可以找机会测试一下

asdf2110 发表于 2015-03-20 08:43

恩,把这种字段设置成 bigint 或 numeric 等
如果你搜“auto_increment 重置”,会提供到两种方法,一种是 truncate table,还有一种 recreate
不过这两种都需要重新导入数据,代价会比较大

回复 5# number321


   
页: [1]
查看完整版本: 如果自增长的id值超过了字段表示范围会怎么样?