Как использовать T-SQL MERGE в этом случае? - PullRequest
3 голосов
/ 03 июня 2010

Я новичок в команде T-SQL MERGE, поэтому я нашел место в своей логике SQL, где я могу его использовать и хочу проверить, но не могу понять, как именно его использовать:

IF (EXISTS (SELECT 1 FROM commissions_history WHERE request = @requestID))
    UPDATE commissions_history
    SET amount = @amount
    WHERE request = @requestID
ELSE
    INSERT INTO commissions_history (amount) VALUES @amount)

Пожалуйста, предложите правильное использование. Спасибо!

Ответы [ 2 ]

13 голосов
/ 03 июня 2010

Вы смотрели в помощь? Вот простой пример:

MERGE dbo.commissions_history AS target
USING (SELECT @amount, @requestID) AS source (amount, request)
ON (target.request = source.request)
WHEN MATCHED THEN
    UPDATE SET amount = source.amount
WHEN NOT MATCHED THEN
    INSERT (request, amount)
    VALUES (source.request, source.amount);
1 голос
/ 03 июня 2010

Я надеюсь, что это будет работать

MERGE commissions_history AS target
USING (SELECT request FROM  commissions_history WHERE request = @requestID) AS source (request)
ON (target.request = source.request)
WHEN MATCHED THEN 
    UPDATE SET amount = @amount
WHEN NOT MATCHED BY SOURCE    
    INSERT (request, amount)
    VALUES (@requestID,  @amount)
...