Использование новой команды merge
в SQL Server 2008, насколько я могу понять, будет:
merge Table t
using (select 1000 as Something, 1 as Qty) s on t.Something = s.Something
when matched then
update set t.Qty = t.Qty + 1
when not matched by target then
insert values (s.Something, s.Qty);
Это не так просто, поскольку объединение более эффективно для объединения больших наборов, а не только одной записи. В противном случае вы можете просто попытаться обновить запись и вставить ее, если записи не были обновлены:
update Table set Qty = Qty + 1 where Something = 1000
if (@@rowcount = 0) begin
insert into Table (Something, Qty) values (1000, 1)
end