在 SQL Server 2008 R2 中,我有一个允许 0 作为外键的表。这很奇怪,因为指定了主键约束,并且IDENTITY(1,1)
还使用了描述符。
当第一条记录插入到表中时,它的 PK ( RegionID
) 为 0。
我在插入时没有IDENTITY-INSERT
打开。(普通手术)
这是表定义:
CREATE TABLE [dbo].[tdfRegions](
[RegionID] [int] IDENTITY(1,1) NOT NULL,
[RegionName] [nvarchar](50) NOT NULL,
[RegionDescription] [nvarchar](50) NOT NULL,
[Active] [bit] NOT NULL,
CONSTRAINT [PK_tdfRegions] PRIMARY KEY CLUSTERED
(
[RegionID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
GO
我一直在假设插入到该表的第一条记录的 aRegionID
为 1。
INSERT INTO
tdfRegions (RegionName, RegionDescription, Active)
VALUES
('test','test', 1)
产生:
RegionID RegionName RegionDescription Active
0 test test 1
为什么会发生这种情况?
编辑:
好的,我在这里有更多的背景信息。有人跑了
EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL'
GO
EXEC sp_MSForEachTable 'DELETE FROM ?'
GO
EXEC sp_MSForEachTable 'ALTER TABLE ? CHECK CONSTRAINT ALL'
GO
首次创建时清除数据库。这可能是负责任的吗?