Arithmetic overflow error converting IDENTITY to data type int(SqlServer主键自增长引起的问题)

这是项目中真实存在的问题,最后导致全部项目瘫痪!查了两个小时才查出来的问题

背景:突然早上上班前被告知所有项目的灯不能正常关闭,天了噜,这可不能发生,这个以前也没有发生啊。赶紧赶到公司,先用预备方案给所有设备发送指令进行关闭。然后开始找问题。

过程:一开始以为服务器或者IIS出现了问题,因为以前IIS经常隔一段时间就死掉,需要重启。但是这次很显然不是,因为网站是可以正常访问的。那么就查服务了。查了半天发现有一段代码报了错,只是简单的更新数据库的语句。

类似:update xxx set xx=x where xxxx=xxxx

这样的语句报错Arithmetic overflow error converting IDENTITY to data type int

虽然英语不好,但是能看出来是转换类型出错了,转换int类型出错,主键标识列,溢出。但是肯定这条语句肯定没问题啊,还是想到有一个这个表更新之后触发器。那么就看触发器,发现有一项插入到其他表的工作,再看那个表的主键是int类型。瞬间明白了,因为那个表一天会存入数万条数据,虽然会定时清空,但是自增长id会增长。所以id大于了2亿,也就是2的32次方。

解决方法:将字段类型改为bigint或者varchar类型(guid),虽然bigint也是有限的,但是理论上肯定是没事了!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值