IDENTITY 列上突然发生 PRIMARY KEY 违规

Hei*_*nzi 7 sql-server primary-key identity sql-server-2012

我有一个log带有ID标识列的表。多年来一切正常;然后,昨天,我在日志中看到以下错误:

该语句已终止。
违反 PRIMARY KEY 约束“PK__log__ID__3B40CD36”。无法在对象“dbo.log”中插入重复键。重复的键值为 (295992)。

INSERT INTO log (datum, zeit, benutzer, modul, prozedur, code, zeile, bez1, bez2, tech_info) VALUES ('20151126 00:00:00.000', '19000101 18:26:45.121','Customer,', , '', 'WShop-Trans', 0, '1 Datensätze für Tabelle adresse gesendet.', '', '')

我检查了 IDENTITY 种子,看起来没问题:

查询:DBCC CHECKIDENT(log)

结果:正在检查身份信息:当前身份值“296021”,当前列值“296021”。
DBCC 执行完成。如果 DBCC 打印错误消息,请联系您的系统管理员。

查询:SELECT MAX(ID) FROM 日志

结果:296021

表上没有触发器,也没有人弄乱种子值(我是管理数据库服务器的人,所以我很确定)。

到目前为止,这是一次性事件,我无法重现。

我看起来只是一个 SQL Server 故障,但我很好奇:这是一个已知的错误,还是对此有任何其他合理的解释?SQL Server 版本是Microsoft SQL Server 2012 - 11.0.2100.60 (X64).

为了完整起见,这里是完整的表脚本:

CREATE TABLE [log](
    [datum] [datetime] NULL,
    [ID] [int] IDENTITY(1,1) NOT NULL,
    [zeit] [datetime] NULL,
    [benutzer] [varchar](255) NULL,
    [modul] [varchar](255) NULL,
    [prozedur] [varchar](255) NULL,
    [code] [varchar](255) NULL,
    [zeile] [int] NULL,
    [bez1] [text] NULL,
    [bez2] [text] NULL,
    [tech_info] [text] NULL,
    [pc_name] [varchar](255) NULL,
    [app_name] [varchar](255) NULL,
    [s_insert_user] [nvarchar](255) NULL,
    [s_insert_dat] [datetime] NULL,
    [s_update_user] [nvarchar](255) NULL,
    [s_update_dat] [datetime] NULL,
    [fs_mandant] [uniqueidentifier] NULL,
 CONSTRAINT [PK__log__ID__3B40CD36] PRIMARY KEY CLUSTERED ([ID] ASC)
)

CREATE NONCLUSTERED INDEX [code] ON [log] ([code] ASC)
CREATE NONCLUSTERED INDEX [datum_zeit] ON [log] ([datum] ASC, [zeit] ASC)
CREATE NONCLUSTERED INDEX [fs_mandant] ON [log] ([fs_mandant] ASC)
CREATE NONCLUSTERED INDEX [modul] ON [log] ([modul] ASC)
Run Code Online (Sandbox Code Playgroud)

小智 7

由于问题说明 SQL Server 2012 RTM (build 2100) is in use,很可能是这个错误:

修复:当 SQL Server 2012 或 SQL Server 2014 处于内存压力下时,序列对象会生成重复的序列值

其中说:

假设您创建的序列对象CACHE在 Microsoft SQL Server 2012 或 SQL Server 2014 中启用了该选项。当实例处于内存压力下,并且多个并发连接从同一序列对象请求序列值时,可能会生成重复的序列值。此外,将重复的序列值插入到表中时,会发生唯一或主键 (PK) 违规错误。

请注意,IDENTITY在 SQL Server 2012 及更高版本中使用序列对象机制。

该问题首先在以下位置修复:

  • SQL Server 2014 累积更新 6
  • SQL Server 2012 SP2 的累积更新 4