sqlserver自动增长列的定时炸弹(自动增长列溢出)

在sqlserver数据库设计时,往往我们会增加一个名为ID类型为int的自动增长列用来作为表的主键,IDENTITY(1,1)。

随着数据的增加,当数据达到20亿左右的时候,就会出现“错误提示:发生算术溢出。将 IDENTITY 转换为数据类型 int 时出现算术溢出错误。”的插入报错。那么此时我们该怎么办呢?

一、一劳永逸的办法

不采用int类型的自动增长的办法做唯一标识的主键。我们采用GUID,如下

CREATE TABLE cust

(

ID uniqueidentifier NOT NULL --由于newid()函数得到的是uniqueidentifier 类型的值

DEFAULT newid(),

Company varchar(30) NOT NULL

)

GO

二、已经采用了int类型的自动增长列的补救办法,可以把字段的类型改成bigint类型,这样就可以存放大约900万亿的数据,900万亿,也够存放了吧。

三、重新编号的办法,只适用于ID在增长,但是历史数据在删除的情况下。

1、truncate table TableName

删除所以数据,然后重新编号

2、DBCC CHECKIDENT ('TableName', RESEED, 0)

表自动重新编号,历史数据不会有改变,但是新添加的数据会从1开始编号

3、先备份现有表的数据,然后使用truncate table TableName删除所有数据,然后把备份的数据循环插入到表中。

你可能感兴趣的:(sqlserver自动增长列的定时炸弹(自动增长列溢出))