我正在从多个进程插入 SQL 数据库。这些进程有时可能会尝试将重复数据插入表中。我尝试以处理重复项的方式编写查询,但我仍然得到:
System.Data.SqlClient.SqlException: Violation of UNIQUE KEY constraint 'UK1_MyTable'. Cannot insert duplicate key in object 'dbo.MyTable'.
The statement has been terminated.
我的查询看起来像这样:
INSERT INTO MyTable (FieldA, FieldB, FieldC)
SELECT FieldA='AValue', FieldB='BValue', FieldC='CValue'
WHERE (SELECT COUNT(*) FROM MyTable WHERE FieldA='AValue' AND FieldB='BValue' AND FieldC='CValue' ) = 0
约束“UK1_MyConstraint”表示在 MyTable 中,3 个字段的组合应该是唯一的。
我的问题:
- 为什么这不起作用?
- 我需要进行哪些修改才能避免因违反约束而出现异常?
请注意,我知道还有其他方法可以解决“如果不存在则插入”的原始问题,例如(总而言之):
- 使用 TRY CATCH
- IF NOT EXIST INSERT(在具有可序列化隔离的事务内)
我应该使用其中一种方法吗?
Edit 1创建表的SQL:
CREATE TABLE [dbo].[MyTable](
[Id] [bigint] IDENTITY(1,1) NOT NULL,
[FieldA] [bigint] NOT NULL,
[FieldB] [int] NOT NULL,
[FieldC] [char](3) NULL,
[FieldD] [float] NULL,
CONSTRAINT [PK_MyTable] PRIMARY KEY NONCLUSTERED
(
[Id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON),
CONSTRAINT [UK1_MyTable] UNIQUE NONCLUSTERED
(
[FieldA] ASC,
[FieldB] ASC,
[FieldC] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON)
)
Edit 2决定:
只是为了更新这一点 - 我决定使用链接问题中建议的“JFDI”实施(link https://stackoverflow.com/questions/3407857/only-inserting-a-row-if-its-not-already-there/3408196#3408196)。尽管我仍然很好奇为什么最初的实现不起作用。