以下の埋め込み 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
デッドロックを克服するための提案は本当に感謝しています。
前もって感謝します。--ラージ