将从多个进程插入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

用于创建表的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)
)

杀马特杀马特提问于
奔Reborn回答于

可以尝试性爱

Tran A                                Tran B
---------------------------------------------
SELECT COUNT(*)...
                                  SELECT COUNT(*)...
INSERT ....
                                  INSERT... (duplicate key violation).

在SQLProfiler中

创建表脚本

create table MyTable
(
FieldA int NOT NULL, 
FieldB int NOT NULL, 
FieldC int NOT NULL
)
create unique nonclustered index ix on  MyTable(FieldA, FieldB, FieldC)

然后将下面的内容粘贴到两个不同的SSMS窗口中

插入脚本

DECLARE @FieldA INT, @FieldB INT, @FieldC INT
SET NOCOUNT ON
SET CONTEXT_INFO 0x696E736572742074657374

BEGIN TRY
WHILE 1=1
    BEGIN

        SET @FieldA=( (CAST(GETDATE() AS FLOAT) - FLOOR(CAST(GETDATE() AS FLOAT))) * 24 * 60 * 60 * 300)
        SET @FieldB = @FieldA
        SET @FieldC = @FieldA

        RAISERROR('beginning insert',0,1) WITH NOWAIT
        INSERT INTO MyTable (FieldA, FieldB, FieldC)
        SELECT FieldA=@FieldA, FieldB=@FieldB, FieldC=@FieldC
        WHERE (SELECT COUNT(*) FROM MyTable WHERE FieldA=@FieldA AND FieldB=@FieldB AND FieldC=@FieldC ) = 0
    END
END TRY
BEGIN CATCH
    DECLARE @message VARCHAR(500)
    SELECT @message = 'in catch block ' + ERROR_MESSAGE()
    RAISERROR(@message,0,1) WITH NOWAIT
    DECLARE @killspid VARCHAR(10) 
    SELECT @killspid = 'kill ' +CAST(SPID AS VARCHAR(4)) FROM sys.sysprocesses WHERE SPID!=@@SPID AND CONTEXT_INFO = (SELECT CONTEXT_INFO FROM sys.sysprocesses WHERE SPID=@@SPID)
    EXEC ( @killspid )
END CATCH

回答过的其他问题

在ASP.net MVC中正确捆绑DataTables

好吧,这是两件事的组合。第一个是我没有在我应该拥有的包中包含一个css文件(文件jquery.dataTables.css),并且最重要的是我使用的是实际存在的目录。将附加文件添加到捆绑包并更改为不存在的导向器会修复它。

使用is测试Vue过滤器

如果你在多个组件中使用filters,那么它很容易测试。 由于Vue.filter只需要一个函数,你可以通过导出定义来独立于过滤器编写函数的测试,如下所示: // Define the function independently and export it export co...... 展开详请

如何解决Java表示0年是闰年,但0年从未存在过?

......天文年编号(与公元前1年的朱利安年份一致)和ISO 8601:2004(公元前1年的格里高利年)一致

Bootstrap固定内容在表中?

使用您的代码似乎在这个小提琴中正常工作。 http://jsfiddle.net/joshmoto/hapzr61g/ 你脑子里有正确的meta标签吗? <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf...... 展开详请

Electron-Typescript:捆绑一切?

Crossfilter.js在pandas中的group()行为?

如果没有一个好的答案,这就是我拼凑在一起的东西。它需要将过滤器编码到树中,以便可以在每次传递中遍历它并使相应的系列过滤器无效。我仍然对更好的解决方案感兴趣。 基于上述问题的示例调用,其中df是pandas数据帧: crossfilter(df, ('eq', 'Make', '...... 展开详请

关于作者

所属标签

扫码关注云+社区