2

Microsoft SQL Server 2008で次のように記述しますか?

IF EXISTS(SELECT * FROM Table WHERE Something=1000)
UPDATE Table SET Qty = Qty + 1 WHERE Something=1000
ELSE
INSERT INTO Table(Something,Qty) VALUES(1000,1)
4

2 に答える 2

4
IF EXISTS(SELECT * FROM Table WHERE Something=1000)
BEGIN
 UPDATE Table SET Qty = Qty + 1 WHERE Something=1000
END
ELSE
BEGIN
 INSERT INTO Table(Something,Qty) VALUES(1000,1)
END
于 2010-05-26T20:36:55.013 に答える
3

SQL Server 2008で新しいmergeコマンドを使用すると、私が収集できる限り、次のようになります。

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
于 2010-05-26T20:49:20.490 に答える