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 及更高版本中使用序列对象机制。
该问题首先在以下位置修复:
归档时间: |
|
查看次数: |
5244 次 |
最近记录: |