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

回答过的其他问题

为什么我不能将SizeTransition水平居中于Flutter中的列?

我可以看到你已经尝试了很多东西,这里有一些想法: #1 Column( crossAxisAlignment: CrossAxisAlignment.center, children: // ... ) 要么 #2 Column( crossAxisAlignme...... 展开详请

在被切除的猫头鹰转盘的项目的箱子阴影

或者您可以尝试为类添加页边距:

.owl-stage{
    margin: 30px;}

如何在解析异步函数之后继续使嵌套循环继续,或者如何将“.then”扩展到范围之外

已采纳
我不认为我完全理解你写的代码。但是,我建议你使用Promise.all。这是我写的一个例子,希望能帮助指导你: let total = []; $.each([1,2,3,4], function (data) { // Some other code. let out...... 展开详请

在Odata v3中,状态码为200的C#“未找到该段的资源”错误

如果您想要快速解决问题,可以分析response.Content属性以获取相关的错误消息。

但是,如果您希望以更传统的方式执行此操作,则可以考虑使用Proper OData客户端而不是手动调用HttpClient

使用未声明的标识符'vpaddq_u8'

我相信这里的问题是你不仅要为ARM编译相同的代码,还要为x86编译相同的代码。 NDK也有一个版本的arm_neon.h也用于x86,它有一套不完整的ARM内在函数,它使用不同的SSE内在函数模拟它们。即使对于x86,这也允许使用相同的SIMD代码,但不会获得最佳性能。(这是否...... 展开详请

mktime和tm_isdst

已采纳
我认为最初的原因是某些时区没有夏令时。由于mktime不是异步安全的,也不是可重入的,因此允许实现将夏令时的当前值存储在POSIX extern char tzname [2]中,由daylight [0或1]索引。这意味着tzname [0] =“[std TZ name]”...... 展开详请

所属标签

扫码关注云+社区