免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 13255 | 回复: 6
打印 上一主题 下一主题

如果自增长的id值超过了字段表示范围会怎么样? [复制链接]

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-01-01 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-03-18 20:11 |只看该作者 |倒序浏览
我有一个表,每天会插入上千万条数据,但是只保留几天内的,旧数据会清除。
但是这样的话,id仍然是一直增长的,我的id设置为int,理论上能表示42亿的数字,但按照这样的速度,很会很快用完的,如果id值增长到int表示范围的上限,会发生什么呢?

论坛徽章:
7
数据库技术版块每日发帖之星
日期:2015-08-08 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-09-18 06:20:00数据库技术版块每周发帖之星
日期:2015-11-06 19:56:51数据库技术版块每日发帖之星
日期:2016-01-22 06:20:00数据库技术版块每日发帖之星
日期:2016-02-05 06:20:00
2 [报告]
发表于 2015-03-19 14:10 |只看该作者
可以在 tinyint 列上做个测验


回复 1# number321


   

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-01-01 06:20:00
3 [报告]
发表于 2015-03-19 15:39 |只看该作者
回复 2# asdf2110


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

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

论坛徽章:
7
数据库技术版块每日发帖之星
日期:2015-08-08 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-09-18 06:20:00数据库技术版块每周发帖之星
日期:2015-11-06 19:56:51数据库技术版块每日发帖之星
日期:2016-01-22 06:20:00数据库技术版块每日发帖之星
日期:2016-02-05 06:20:00
4 [报告]
发表于 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


   

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-01-01 06:20:00
5 [报告]
发表于 2015-03-19 19:24 |只看该作者
回复 4# asdf2110


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

论坛徽章:
224
2022北京冬奥会纪念版徽章
日期:2015-08-10 16:30:32操作系统版块每日发帖之星
日期:2016-02-18 06:20:00操作系统版块每日发帖之星
日期:2016-03-01 06:20:00操作系统版块每日发帖之星
日期:2016-03-02 06:20:0015-16赛季CBA联赛之上海
日期:2019-09-20 12:29:3219周年集字徽章-周
日期:2019-10-01 20:47:4815-16赛季CBA联赛之八一
日期:2020-10-23 18:30:5320周年集字徽章-20	
日期:2020-10-28 14:14:2615-16赛季CBA联赛之广夏
日期:2023-02-25 16:26:26CU十四周年纪念徽章
日期:2023-04-13 12:23:1015-16赛季CBA联赛之四川
日期:2023-07-25 16:53:45操作系统版块每日发帖之星
日期:2016-05-10 19:22:58
6 [报告]
发表于 2015-03-19 20:05 来自手机 |只看该作者
这类问题还没接触过,可以找机会测试一下

论坛徽章:
7
数据库技术版块每日发帖之星
日期:2015-08-08 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-08-29 06:20:00数据库技术版块每日发帖之星
日期:2015-09-18 06:20:00数据库技术版块每周发帖之星
日期:2015-11-06 19:56:51数据库技术版块每日发帖之星
日期:2016-01-22 06:20:00数据库技术版块每日发帖之星
日期:2016-02-05 06:20:00
7 [报告]
发表于 2015-03-20 08:43 |只看该作者
恩,把这种字段设置成 bigint 或 numeric 等
如果你搜“auto_increment 重置”,会提供到两种方法,一种是 truncate table,还有一种 recreate
不过这两种都需要重新导入数据,代价会比较大

回复 5# number321


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP