INSERT or UPDATE | NoConcurrent
Версия 5.5 от Alexandr Fokin на 2022/01/03 14:54
DECLARE @key INT = 12
DECLARE @msg NVARCHAR(MAX) = 'L2'
BEGIN TRAN
IF EXISTS (
SELECT *
FROM DBO.LOG2ENTITY WITH (UPDLOCK, SERIALIZABLE)
WHERE ID = @key
)
BEGIN
UPDATE DBO.LOG2ENTITY
SET
Message = @msg
WHERE ID =@key
END
ELSE
BEGIN
INSERT INTO DBO.LOG2ENTITY (Message)
VALUES (@msg)
END
COMMIT TRAN
DECLARE @msg NVARCHAR(MAX) = 'L2'
BEGIN TRAN
IF EXISTS (
SELECT *
FROM DBO.LOG2ENTITY WITH (UPDLOCK, SERIALIZABLE)
WHERE ID = @key
)
BEGIN
UPDATE DBO.LOG2ENTITY
SET
Message = @msg
WHERE ID =@key
END
ELSE
BEGIN
INSERT INTO DBO.LOG2ENTITY (Message)
VALUES (@msg)
END
COMMIT TRAN