在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删除所有数据,然后把备份的数据循环插入到表中。