我有一个log
带有ID
标识列的表。多年来一切正常;然后,昨天,我在日志中看到以下错误:
该语句已终止。
违反主键约束“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(日志)
结果:检查身份信息:当前身份值“296021”,当前列值“296021”。
DBCC 执行完成。如果 DBCC 打印错误消息,请联系您的系统管理员。查询:SELECT MAX(ID) FROM log
结果: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)
由于问题表明正在使用 SQL Server 2012 RTM(内部版本 2100),因此很可能是这个错误:
修复:当 SQL Server 2012 或 SQL Server 2014 处于内存压力之下时,序列对象生成重复的序列值
其中说:
请注意,
IDENTITY
在 SQL Server 2012 及更高版本中使用序列对象机制。该问题首先在以下位置修复: