0

以下の埋め込み SQL が MS SQL Server 2014 の C# プログラミング言語を介して呼び出されると、Dispatching.PackageTrace テーブルでデッドロックの問題に直面しています。

以下は、データベースのテーブル デザインです。

    CREATE TABLE [Dispatching].[PackageTrace](
[PackageID] [uniqueidentifier] ROWGUIDCOL  NOT NULL,
[PartitionID] [numeric](26, 0) NULL,
[Conduit] [nvarchar](255) NOT NULL,
PRIMARY KEY CLUSTERED 
  (
    [PackageID] ASC
  )    GO

SET ANSI_PADDING OFF
GO

ALTER TABLE [Dispatching].[PackageTrace] ADD  DEFAULT (getdate()) FOR [DateCreated]
GO

以下の埋め込み SQL は、MS SQL Server 2014 の C# プログラミング言語を介して呼び出されます。

IF EXISTS(SELECT * FROM Dispatching.PackageTrace WHERE PackageID = 'klaslndsskok230m')
    BEGIN
            UPDATE [Dispatching].[PackageTrace] SET [Conduit] = @Conduit                WHERE [PackageID] = 'klaslndsskok230m'
    END
ELSE 
    BEGIN
        INSERT INTO [Dispatching].[PackageTrace] ([PackageID] ,[PartitionID] ,[Conduit]          VALUES (@PackageID, @PartitionID, @Conduit)
    END

デッドロックを克服するための提案は本当に感謝しています。

前もって感謝します。--ラージ

4

0 に答える 0